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.
Pozdrawiam.
Ajgor
 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
Pozdrawiam.
Ajgor
 System operacyjny: windows_ten Przeglądarka: chrome
#5
RE: [VBA] Przenoszenie danych między formularzami
Pokaż plik.
Nie pomagam na PW (ew. odpłatnie). 
I osobom z roszczeniowym podejściem. I osobom niedbającym o poprawność językową.
Jak podawać logi
Jeśli nie odpowiadam w danym wątku przez >3 dni - proszę o przypomnienie na PW z linkiem do wątku w treści.




 System operacyjny: windows_seven Przeglądarka: firefox
Programy: Polecane / Nowe / Inne




Podobne wątki ([VBA] Przenoszenie danych między formularzami)
Wątek: Autor Odpowiedzi: Wyświetleń: Ostatni post
  VBA excel dmjs 6 5225 17.04.2019, 10:20
Ostatni post: ptrick
  [VBA] Tworzenie nowego arkusza z danymi z TextBox'a Pioro 4 9545 19.06.2018, 23:24
Ostatni post: broda99
  VBA Pobieranie wybranych plików z danymi julietta03 1 9445 04.05.2018, 08:25
Ostatni post: broda99

Skocz do:


Wybrane wątki ([VBA] Przenoszenie danych między formularzami)
Wątek: Autor Odpowiedzi: Wyświetleń: Ostatni post
  Transfer plików via FTP Visual Basic FireBytes 3 4397 15.08.2019 07:41
Ostatni post: Szachista
  Menu wysuwane z boku patryk67 1 2141 07.08.2019 12:43
Ostatni post: aht
  Visual Basic Excel l.całkowitą przedstawić w postaci szesnastkowej fugaz 4 3652 18.06.2019 21:36
Ostatni post: fugaz
  Nauka do Olimpiady Informatycznej? piotr0905 1 3728 08.06.2019 16:50
Ostatni post: wlisik
Ściana Prosta gra w Builder C++ Kiranek1 1 3618 31.05.2019 15:20
Ostatni post: Szachista
  Menu (Nie widoczne długie opisy) wanhelsing 5 5284 28.04.2019 19:31
Ostatni post: koneton
  Skrypt usuwający pliki sylwiaa1 2 2316 28.04.2019 15:20
Ostatni post: sylwiaa1
  Środowisko do assemblera Physicist 4 4968 21.04.2019 14:04
Ostatni post: Ajgor
  VBA excel dmjs 6 5225 17.04.2019 10:20
Ostatni post: ptrick
  C++ - sens pogłębiania nauki gbr 5 5704 25.03.2019 12:53
Ostatni post: koneton
  Klasa wewnętrzna w C++ Physicist 4 5511 23.03.2019 18:28
Ostatni post: Physicist
  Ruby on Rails - tutoriale luciussulla 0 4818 23.03.2019 16:49
Ostatni post: luciussulla
Big Grin Czy dostane sie technikum informatycznego klaudiusz20046 6 7622 21.03.2019 01:28
Ostatni post: UnableToSee
  [C#] Program do moderacji czatów gier wiktrom12 0 5333 07.03.2019 15:33
Ostatni post: wiktrom12
  Mój pierwszy projekt - Pomoc rafal12999 1 5855 07.02.2019 22:01
Ostatni post: Szachista