Top-Themen

Aktuelle Themen (A bis Z)

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, 1407 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 ..
Ähnliche Inhalte
VB for Applications
Excel VBA Formel "WENN" einfügen
gelöst Frage von chef1568VB for Applications2 Kommentare

Hallo zusammen, ich möchte per Excel-Makro folgende Formel eintragen: EXCEL: VBA: Leider bekomme ich hier immer einen anwendungsrelevanten Fehler ...

Microsoft Office
Excel-Formel oder VBA
gelöst Frage von nicki01Microsoft Office7 Kommentare

Hallo Ich weiß nicht, ob ich hier richtig bin. Mein Problem: Ich habe mir (mit Mühe) ein Excel-Haushaltsbuch aufgebaut. ...

Microsoft Office
Excel lösung in VBA oder mit Formel gesucht..
gelöst Frage von Grave111Microsoft Office2 Kommentare

Guten Tag, ich habe folgendes Szenario Das erste Excel Blatt beinhaltet 2 Spalten mit Daten (Spalte A beinhaltet Artikelnummern) ...

Entwicklung
VBA wenn Formel
Frage von TheSB891Entwicklung1 Kommentar

Hallo Zusammen Ich hab da ein kleines Problem und finde leider keine Lösung. Ich habe eine Tabelle die ich ...

Neue Wissensbeiträge
MikroTik RouterOS

Mikrotik - Lets Encrypt Zertifikate mit MetaROUTER Instanz auf dem Router erzeugen

Anleitung von colinardo vor 7 StundenMikroTik RouterOS4 Kommentare

Einleitung Folgende Anleitung ist aus der Lage heraus entstanden das ein Kunde auf seinem Mikrotik sein Hotspot Captive Portal ...

Sicherheit

Sicherheitslücke in HP-Druckern - Firmware-Updates stehen bereit

Information von BassFishFox vor 7 StundenSicherheit

Ein weiterer Grund, dass Drucker keinerlei Verbindung nach "auswaerts" haben sollen. Unter Verwendung spezieller Malware können Angreifer aus der ...

Administrator.de Feedback

Entwicklertagebuch: Die Startseite wurde überarbeitet

Information von admtech vor 9 StundenAdministrator.de Feedback9 Kommentare

Hallo Administrator User, mit dem Release 5.7 haben wir unsere Startseite überarbeitet und die Beiträge und Fragen voneinander getrennt. ...

Vmware

VMware Desktopprodukte sind verwundbar

Information von Penny.Cilin vor 14 StundenVmware

Die VMware-Anwendungen zum Umgang mit virtuellen Maschinen Fusion, Horizon Client und Workstation sowie die Plattform NSX sind verwundbar. Davon ...

Heiß diskutierte Inhalte
Visual Studio
Vb.net-Tool zum Erzeugen einer Outlook-E-Mail
Frage von ahstaxVisual Studio24 Kommentare

Hallo, ich möchte gerne ein vb.net-Tool schreiben, das am Ende eine Outlook-E-Mail erzeugt. Grundsätzlich ist mir klar, wie das ...

Windows Server
RDP macht Server schneller???
Frage von JaniDJWindows Server16 Kommentare

Hallo Community, wir betrieben seit geraumer Zeit diverse virtuelle Maschinen und Server mit Windows Server 2012. Leider haben wir ...

Windows Netzwerk
Netzwerk Neustrukturierung
Frage von IT-DreamerWindows Netzwerk16 Kommentare

Hallo verehrte Community und Admins, bei uns im Haus steht eine Neustrukturierung an. Dafür benötige ich von euch ein ...

Windows 10
Windows 10 dunkler Bildschirm nach Umfallen
Frage von AkcentWindows 1015 Kommentare

Hallo, habe hier einen Windows 10 Rechner der von einem User umgefallen wurde (Beine übers Knie, an den PC ...