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 6477 17.04.2019, 10:20
Ostatni post: ptrick
  [VBA] Tworzenie nowego arkusza z danymi z TextBox'a Pioro 4 10281 19.06.2018, 23:24
Ostatni post: broda99
  VBA Pobieranie wybranych plików z danymi julietta03 1 10184 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
  .bat nie kompresuje plików GIENTY 3 8745 06.09.2018 07:20
Ostatni post: broda99
  problem z programem .bat wiktrom12 4 9901 30.08.2018 08:25
Ostatni post: wiktrom12
  Silnik do gier ZigglerGames 1 8570 23.08.2018 09:03
Ostatni post: Szachista
  Chciałbym zrobić prosty plik exe z jedną funkcją densour 4 9323 09.08.2018 16:24
Ostatni post: Ajgor
  Który język wybrać do stworzenia aplikacji synchronizujące pliki z urządzeniem mobiln Elemental 2 2444 18.07.2018 12:05
Ostatni post: Ajgor
  Pomysł napisania programu ROM FireBytes 3 9934 28.06.2018 16:56
Ostatni post: FireBytes
  [VBA] Tworzenie nowego arkusza z danymi z TextBox'a Pioro 4 10281 19.06.2018 23:24
Ostatni post: broda99
  Potwierdzenie na maila po wysłaniu pliku coci 0 9399 13.06.2018 20:37
Ostatni post: coci
  Pieczętowanie Archiwum Jar - Po co? wanhelsing 3 9984 19.05.2018 20:55
Ostatni post: koneton
  Wyszukiwarka w spawnerze nie reaguje na polskie znaki kazik666 0 9796 16.05.2018 12:04
Ostatni post: kazik666
  BASH symulator silnika dawswi1 3 10288 13.05.2018 10:43
Ostatni post: Szachista
  Autohotkey automatyczny zapis TheProgson 0 9905 07.05.2018 21:27
Ostatni post: TheProgson
  VBA Pobieranie wybranych plików z danymi julietta03 1 10184 04.05.2018 08:25
Ostatni post: broda99
  Skrypt, który szuka i zamienia armen10 2 10143 23.04.2018 10:04
Ostatni post: armen10
  Liniowa regresja w Pythonie a budowanie modelu Trojan3000 2 10305 16.04.2018 13:26
Ostatni post: Trojan3000