Witamy na forum PC Format Zapraszamy do REJESTRACJI


Użytkownicy przeglądający ten wątek: 1 gości

[VBA] Przenoszenie danych między formularzami

#1
[VBA] Przenoszenie danych między formularzami
Witam,

Mam taki problem, otóż piszę program, który ma za zadanie obliczyć pewną przekładnie, pod przyciskiem oblicz wprowadziłem wszystkie potrzebne wzory itd. Wszystko działa i wprowadza mi wyniki do komórek, natomiast chciałbym dodać przycisk "Wyniki", który otworzy mi nowy UserForm i w ListBox wyświetli mi uzyskane wynik. Jednak nie wiem jak to zrobić, pytanie czy trzeba upublicznić klasę i wtedy jakoś wysyłać to?

Dodatkowo bez problemu przesyłam wyniki z jednego TextBox'a do drugiego między formularzami. Natomiast tutaj chciałbym przesłać wyniki z przycisku który jest w UserForm1 do ListBox w UserForm2. Prosiłbym o jakąś pomoc Wesoły Bo szukałem na necie rozwiązania ale wiele przykładów jest jak pobierać z komórek do ListBox'a.

Dzięki
ZADRZYJ Z NAJLEPSZYM, UMRZESZ JAK RESZTA.
 System operacyjny: windows_ten Przeglądarka: firefox
#2
RE: [VBA] Przenoszenie danych między formularzami
Nie mam do czynienia z VBA, ale myślę, że można to rozwiązać podobnie, jak w Visual C#. A tu sposobów jest nawet kilka.
Ja bym wszystkie wartości z komórek wpisał do Kolekcji. Poniżej daję linka, jak tworzy się kolekcje w VBA, a następnie tworząc nowy UserForm przekazał bym mu tą kolekcję w konstruktorze, i w tym nowym UserForm odczytał bym wartości z kolekcji i przepisał je do ListBoxa w pętli Foreach.

Tu masz obszerny artykuł, jak używać kolekcji w VBA (Jest tam też pokazane, jak odczytać kolekcję w pętli foreach, a także jak je odczytać w normalnej pętli for):

https://excelmacromastery.com/excel-vba-collections/

Jeśli chcesz natomiast przepisać nie tylko zawartość komórek, ale też ich współrzędne, musisz utworzyć nową klasę, i w niej trzy właściwości - Zawartość komórki, współrzędną X i współrzędną Y, a następnie utworzyć listę instancji tej klasy. Do każdej instancji wpisać po kolei zawartość komórek, współrzędne, i dodać do listy. A w nowej formie po prostu to odczytać i odpowiednio obrobić. Brzmi skomplikowanie, ale zapewniam, że jest bardzo proste.
Ajgor

Najnowszy klip mojego zespołu: TAMP - Hallelujah
 System operacyjny: windows_ten Przeglądarka: chrome
#3
RE: [VBA] Przenoszenie danych między formularzami
Dzięki za pomoc Wesoły


Zrobiłem to trochę w inny sposób niż mi podesłałeś i teraz pytanie mam takie czy ten sposób, który ja zrobiłem jest poprawny, mianowicie:

1. Upubliczniłem potrzebne klasy i na początku przypisałem ogólne zmienne, tak aby ich nie powtarzać w poszczególnych klasach plus.
2. Następnie pod przyciskiem "Oblicz" wstawiłem wzory i tam zostały obliczone parametry i zapamiętane w pamięci.
3. Dzięki upublicznieniu klas drugi przycisk (oba przyciski są w tym samym UserForm) "Wyniki" pobiera zmienne ogólne i wstawiłem następujący kod:


Kod:
UserForm5.ListBox1.ColumnCount = 2

UserForm5.ListBox1.AddItem "Liczba zębów"
UserForm5.ListBox1.List(0, 1) = z2

UserForm5.ListBox1.AddItem "Moduł"
UserForm5.ListBox1.List(1, 1) = mte

UserForm5.Show


4. W UserForm5 wstawiłem ListBox1 i pod odpaleniu wszystko działa i nie wyskakują błędy.

Teraz pytanie do osób związanych z programowaniem (bo ja od zera dopiero się uczę Wesoły ), jest to w miarę poprawny kod i sposób rozumowania? Całe makro jest w Excelu i będzie służyć tylko do obliczenia przekładni stożkowych w ramach pracy dyplomowej. Został jedynie mi tylko ten problem do rozwiązania i nie wiem czy go rozwiązałem poprawnie. Wesoły
ZADRZYJ Z NAJLEPSZYM, UMRZESZ JAK RESZTA.
 System operacyjny: windows_ten Przeglądarka: firefox
#4
RE: [VBA] Przenoszenie danych między formularzami
Nie wiem, czy zrobiłeś dobrze, bo tak niejasno to opisałeś, że niewiele z tego zrozumiałem Wesoły Generalnie upublicznianie czegokolwiek jest złą metodą, bo łamie tzw. enkapsulację, ale jeśli działa, to niech działa Wesoły
Ajgor

Najnowszy klip mojego zespołu: TAMP - Hallelujah
 System operacyjny: windows_ten Przeglądarka: chrome
Programy: Polecane / Nowe / Inne




Podobne wątki ([VBA] Przenoszenie danych między formularzami)
Wątek: Autor Odpowiedzi: Wyświetleń: Ostatni post
  [VBA Excel] Zaokrąglanie liczby w górę Pioro 2 1301 13.02.2018, 21:25
Ostatni post: Pioro
  Pomoc w VBA excel Woof 3 2057 19.01.2018, 09:36
Ostatni post: Woof
  [VB.NET] przenoszenie danych między formami Pioro 15 5945 19.11.2017, 03:48
Ostatni post: broda99

Skocz do:


Wybrane wątki ([VBA] Przenoszenie danych między formularzami)
Wątek: Autor Odpowiedzi: Wyświetleń: Ostatni post
  Batch - zamknięcie programu jeśli jest włączony Mamalama555 2 4179 06.07.2017 15:29
Ostatni post: Mamalama555
  Jak napisać program typu konsola poleceń? toslaw1 6 5207 29.06.2017 18:58
Ostatni post: toslaw1
  Pomoc w VBA EXCEL! dydryjan 1 4263 22.06.2017 20:56
Ostatni post: broda99
  Java początkujący problem ze zrozumieniem kodu MatL70 6 4470 20.06.2017 12:24
Ostatni post: MatL70
  Jezyk C, komenda system, tworzenie kont uzytownikow weis 1 1015 17.06.2017 21:44
Ostatni post: Szachista
  [C#] Zachowanie proporcji okna Niyabi 0 4385 04.06.2017 17:29
Ostatni post: Niyabi
  [C# WPF] Dodawanie elementów z listy do DataGrid Kamil 1 2 4856 25.05.2017 20:03
Ostatni post: Kamil 1
  Pomoc w pętli for BATCH falafal 3 5044 24.05.2017 08:19
Ostatni post: falafal
  Programowanie, od czego zacząć ? Reyo1994 6 5813 22.05.2017 09:09
Ostatni post: joannakulersa
  C# Przechowywanie sporej ilości danych Kamil 1 9 4629 22.05.2017 08:05
Ostatni post: koneton
  Systeminfo.exe - wyświetlanie informacji w Batchu Mamalama555 2 4541 10.05.2017 21:44
Ostatni post: Mamalama555
  Pliki wsadowe z obliczeniami i zakładaniem kont dideek 0 4196 10.05.2017 21:03
Ostatni post: dideek
myBB Praca programisty soul1648 14 10052 29.04.2017 20:44
Ostatni post: Ajgor
  Nauka tworzenia aplikacji w Android Studio- książka do wyboru. raxer 2 5167 11.04.2017 15:12
Ostatni post: raxer
  Rekurencja, zrozumienie soul1648 1 4357 07.04.2017 20:22
Ostatni post: Szachista