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] Wyszukiwanie wartości w kolumnie Pioro 2 6531 22.06.2020, 18:27
Ostatni post: Pioro
  VBA excel dmjs 6 13933 17.04.2019, 10:20
Ostatni post: ptrick
  [VBA] Tworzenie nowego arkusza z danymi z TextBox'a Pioro 4 13510 19.06.2018, 23:24
Ostatni post: broda99

Skocz do:


Wybrane wątki ([VBA] Przenoszenie danych między formularzami)
Wątek: Autor Odpowiedzi: Wyświetleń: Ostatni post
  Portale z nowinkami programistycznymi. Jamuna 3 856 12.01.2021 21:28
Ostatni post: voxcordi
  Licencja LGPL 3 co mogę? DonCorleone 0 1389 13.12.2020 21:23
Ostatni post: DonCorleone
Exclamation pac man c++ kacperson 4 1818 11.12.2020 16:10
Ostatni post: kacperson
  Tworzenie aplikacji thinkPL 0 1707 29.11.2020 21:47
Ostatni post: thinkPL
  Kompilator C++ 17 Physicist 14 4513 26.11.2020 13:56
Ostatni post: Physicist
  Napisz program, który poprosi o podanie numeru PESEL. BigKundzi 1 2558 25.11.2020 15:02
Ostatni post: ptrick
  Nieprawidłowy format ciągu wejściowego. radman 9 3198 05.11.2020 22:08
Ostatni post: Bodzio Chomik
  Wybór języka Xyio 5 3043 30.10.2020 15:07
Ostatni post: bartexo23
  Skrypt usuwający pliki azds1 1 1533 13.10.2020 08:45
Ostatni post: Michu_PL
  Mam mały problem ze zrobieniem tego programu Asasin12PL 2 2900 12.10.2020 17:10
Ostatni post: Asasin12PL
  Skrypt pod sklep internetowy Talcia 6 12687 24.09.2020 22:20
Ostatni post: Ajgor
  Książki do nauki C# olek23 16 31247 28.08.2020 09:51
Ostatni post: Ajgor
  [VBA Excel] Wyszukiwanie wartości w kolumnie Pioro 2 6531 22.06.2020 18:27
Ostatni post: Pioro
  Validacja JS kolo48 3 8220 16.04.2020 14:06
Ostatni post: koneton
  Automatyczne wykonywanie czynności na stronie Fresher 0 7133 15.04.2020 20:53
Ostatni post: Fresher