Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Excel Formel in VBA fummeln

Frage Microsoft Microsoft Office

Mitglied: YotYot

YotYot (Level 1) - Jetzt verbinden

30.12.2014 um 18:13 Uhr, 1363 Aufrufe, 1 Kommentar

Moin!

Ich habe da so eine neckische kleine Excel-Tabelle mit derzeit rund 9 Mio. gefüllten Zellen, von denen 2 Mio. ausgelesen sind (mySQL-DB) und die anderen 7 Mio. sind berechnet. So weit, so schön. Nun bin ich bei rund 62.000 Zeilen, die täglich mehr werden und auch die Spalten werden monatlich zwei mehr. Die Berechnungen funktionieren momentan über eine nicht ganz leicht überschaubare Formel mit diversen Wenns und Oders. Verschachtelt, bis der Arzt kommt, ist klar. So langsam bin ich mit der Tabelle bei rund 85MB Leergewicht, also Dateigröße. Wenn geöffnet, nimmt sich Excel dazu auch mal schnell 1,5GB RAM zu Hilfe.
Immer öfter komme ich jetzt an das Problem, dass die Ressourcen laut Meldung nicht ausreichen, die Rückgängig-Möglichkeit wird regelmäßig abgeschaltet und irgendwie will ich das auch mal ein wenig eleganter haben. Also bin ich auf die Idee gekommen, die an sich nur zwei Formeln in VBA zu schreiben und von den Zellen aus aufzurufen. Das würde auf jeden Fall schon mal eine Menge Speicherplatz für die Zeichenzahl der Formeln sparen.

So sieht das Konstrukt im Moment aus:

Die Spalten A bis AM werden eingelesen bzw. direkt beim Einlesen berechnet. Erste Zeile = Überschrift.
Ab Spalte AN gibt es ab 2012 für jeden Monat eine Spalte, deren erste Zeile ein Datum enthält (immer den Monatsletzten, manuell eingetragen).
In der Zelle AN2 steht nun eine Formel, die sich aus diversen Zellen von A bis AM bedient und aber auch aus AN1, also der Kopfzeile.
Diese Formel ist nun nach rechts und nach unten kopiert worden und berechnet eben die Werte, die am Ende unten summiert werden.

Wie setze ich so ewtas am sinnvollsten in VBA um?

An sich würde ich ja die Offset-Funktion dazu hernehmen, aber wie kriege ich das dynamsich für jeden Monat hin? Definiere ich da eine Zelle als Nullpunkt und zähle, in welcher Zelle ich dann bin oder wie stellt man sowas an? Wenn ich die Formeln in Excel grafisch einfach kopiere, ist das Ding ja schlau genug, die Zellbezüge jeweils mitzunehmen. Aber wie geht das mit VBA?

Einen gepflegten Übergang ins neue Jahr wünsche ich!

Y.
Mitglied: YotYot
15.01.2015 um 08:18 Uhr
Frage als gelöst markiert, damit hier nicht für alle Zeiten eine offene Frage stehen bleibt.

Meine derzeitige Lösung für Kollegen mit einer ähnlichen Anforderung:

Ich setze für die Berechnung der zu summierenden Werte eine Access-Datenbank als Zwischenstufe ein. Hier habe ich zwei aufeinander aufbauende Abfragen erstellt, wovon die zweite auch noch alle Zeilen, in denen es nur Null-Werte gibt, auslässt. Mit Excel rufe ich dann nur noch die Ergebnisse aus Access ab und bereite das alles grafisch auf, mit Diagrammen und Filtermöglichkeiten.

Der Effekt dabei:

Dateigröße Access-DB ist 1,5 mb, die Excel-Tabelle ist bei 3 mb, die Gesamtbearbeitungszeit nis zum Ergebnis ist von 20 Minuten auf 3 Minuten gesunken. Das reicht mir als Ergebnis für eine Weile.
Bitte warten ..
Neuester Wissensbeitrag
Windows 10

Powershell 5 BSOD

(1)

Tipp von agowa338 zum Thema Windows 10 ...

Ähnliche Inhalte
Microsoft Office
gelöst Excel-Formel oder VBA (7)

Frage von nicki01 zum Thema Microsoft Office ...

VB for Applications
Excel VBA Sortierung von Daten (5)

Frage von easy4breezy zum Thema VB for Applications ...

VB for Applications
gelöst Excel VBA Eine oder mehrere Zellen Verschieben (2)

Frage von batchnewbie zum Thema VB for Applications ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
gelöst Server erkennt Client nicht wenn er ausserhalb des DHCP Pools liegt (28)

Frage von Mar-west zum Thema LAN, WAN, Wireless ...

Outlook & Mail
Outlook 2010 findet ost datei nicht (18)

Frage von Floh21 zum Thema Outlook & Mail ...

Windows Server
Server 2008R2 startet nicht mehr (Bad Patch 0xa) (18)

Frage von Haures zum Thema Windows Server ...