Mittwoch, 20. Januar 2010

Wie man Excel seinen Code entlockt

Wie ich das letzte mal festgestellt habe komme ich um eine Code-Extraktion marke Eigenbau nicht herum. Ich hab mich erst mal informiert wie ich über pywin per COM Excel steuern kann. Das gestaltete sich einfacher als ich gedacht hatte!

Excel öffnen und schließen


import win32com.client

# Neue Instanz von Excel
excel = win32com.client.Dispatch("Excel.Application")
# Sicherheitsrichtlinien speichern und Makros deaktivieren
security = excel.AutomationSecurity
excel.AutomationSecurity = 3
# Workbook öffnen
wbook = excel.Workbooks.Open("C:/Pfad/zur/Excel/datei.xls)

# Code hier einfügen!!

# Sicherheitsrichtlinien zurücksetzen
excel.AutomationSecurity = security
# Workbook schließen (Ohne zu speichern)
wbook.Close(False)
# Excel Instanz schließen
excel.Quit()



Die Sicherheitsrichtlinien stelle ich deshalb um, damit während der Extraktion nicht die wildesten
Makros abgefeuert werden.

Ab hier kommt man mit der gut versteckten aber extrem nützlichen Microsoft Excel 2003 Language Reference weiter, da der zugriff auf die Excel-Objekte wie in VBA läuft ... nur eben toller über listen und so ... Schöööntoll!

Herausgekommen ist das kleine Tool codeXtract, das ihr euch hier herunterladen könnt

Wichtig: Es müssen pywin (Python Library) sowie Excel installiert sein !!

Die Bedienung ist denkbar einfach:
python codeextract.py -i inputpath -o outputpath

wobei inputpath eine XLS-Datei sein kann oder ein Verzeichnis, in dem dann rekursiv alle XLS-Dateien durchsucht werden. Outputpath muss ein Verzeichnis sein. Wenn es noch nicht existiert wird es angelegt. Bei der Extraktion wir die Verzeichnisstruktur (im rekursiven Modus) beibehalten, wobei der Inhalt der XLS-Dateien in ein Verzeichnis mit dem Namensschema [FILE] Dateiname geschrieben wird.

Die Module, Classfiles, etc. werden darin wiederum in Unterordner gepackt, so dass sich eine Struktur ähnlich der im VBA Editor ergibt. Macht man das vor jeden neuen Commit, so lässt sich der Code in Zukunft sauber Versionieren.

Wenn ihr meinen Code nützlich findet würde ich mich über nen kurzen Kommentar freuen. Wenn ich codeXtract noch weiter ausbauen sollte werde ich dann die Ergebnisse hier posten.

2 Kommentare:

  1. Hallo Leute, wenn Sie einen echten Hacker beauftragen müssen, um das Telefon Ihres Partners fernüberwachen / hacken, Ihr gestohlenes Bitcoin in Tagen / Wochen handeln oder wiederherstellen oder eine Datenbank mit garantierter Vertraulichkeit hacken können, wenden Sie sich an easybinarysolutions @ gmail. com oder whatsapp: +1 3478577580, sie sind effizient und vertraulich.

    AntwortenLöschen