🙏 Helfen Sie jetzt mit, unser LibreOffice Forum zu erhalten! 🙏
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀

❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

Excel Datei mit VBA erzeugt Fehler in Libreoffice

CALC ist die Tabellenkalkulation, die Sie immer wollten.
Antworten
trex450
Beiträge: 2
Registriert: Sa 23. Nov 2013, 12:07

Excel Datei mit VBA erzeugt Fehler in Libreoffice

Beitrag von trex450 » Sa 23. Nov 2013, 12:29

Hallo zusammen

Ich habe heute das erste Mal Libreoffice installiert und bin somit neu in der Gemeinde :-)

Gerne möchte ich eine Excel2003 Datei mit VBA (siehe Anhang) in Libreoffice verwenden.
Die Datei im Anhnag (xls) lässt sich zwar starten, jedoch erfolgt ein Fehler nach dem Drücken des Import-Knopfes und anschließender Datei Auswahl (BASIC-Laufzeitfehler. '423' GetOpenFilename).

Gibt es eine Möglichkeit, diese Excel-Datei mit VBA unter LibreOffice zu betreiben.

Vielen Dank für Eure Hilfe.

Liebe Grüsse Fritz

P.S.
Das VBA hat mir ein Kollege geschrieben. Ich selber kann kein VBA.

Die Funktion ist folgende:
Das Excel dient zum Berechnen von Kosten für einziele Kollegen bei Sammelbestellungen aus China.
Die Hauptaufgabe des VBA-Programmes ist es, die Auftragsbestätigung (im Textformat) in eine Tabelle zu Importieren und Stückzahl, Beschreibung und Preis zu trennen.
Die restlichen Berechnungen laufen außerhalb VBA.
Das Dokument im Anhang bebildert die korrekte Funktionsweise in EXCEL 2003
Dateianhänge
Ordercalc.odt
Bebilderung Funktionsweise in Excel 2003
(128.33 KiB) 102-mal heruntergeladen
OrderCalc_v5-6_test.xls
Excel 2003 Datei mit VBA
(85 KiB) 102-mal heruntergeladen

Benutzeravatar
karolus
* LO-Experte *
Beiträge: 2539
Registriert: Fr 10. Dez 2010, 10:01

Re: Excel Datei mit VBA erzeugt Fehler in Libreoffice

Beitrag von karolus » Sa 23. Nov 2013, 14:28

Hallo

Mit Dateiauswahldialog und ~30 Zeilen Python:

Code: Alles auswählen

import uno
from os.path import dirname


ctx = uno.getComponentContext()
servicemanager = ctx.ServiceManager
createUnoService = servicemanager.createInstance




def csv_import(*dummy):
    doc = XSCRIPTCONTEXT.getDocument()
    url  = dirname(doc.URL)
    inputpath = FilePicker(url, 0)
    if inputpath:
        out=[]
        with open(inputpath) as sourcefile:
            for line in sourcefile:
                anzahl, rest = line.split('x #', 1 )
                bezeichnung, preis = rest.rsplit(' = $',1)
                out.append((int(anzahl), bezeichnung, float(preis)))
        sheet = doc.Sheets.getByIndex(0)
        outrange = sheet.getCellRangeByPosition(0, 17, 2, 16 + len(out))
        outrange.setDataArray(tuple(out))



def FilePicker(prechoose, write):
    filepicker = createUnoService( "com.sun.star.ui.dialogs.OfficeFilePicker" )
    filepicker.setDisplayDirectory( prechoose )
    filepicker.initialize( ( write,) )
    if filepicker.execute():
        return uno.fileUrlToSystemPath( filepicker.getFiles()[0] )
 
OrderCalc_mit_python.ods
(40.51 KiB) 119-mal heruntergeladen
Karolus
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)

trex450
Beiträge: 2
Registriert: Sa 23. Nov 2013, 12:07

Re: Excel Datei mit VBA erzeugt Fehler in Libreoffice

Beitrag von trex450 » Sa 23. Nov 2013, 20:55

hallo karolus

vielen dank für die superschnelle lösung. ist der hammer. supi!!
vor lauter freude habe ich doch gleich eine spende an libreoffice entrichtet.

lebe wohl EXCEL ;-)

gruss fritz

p.s.
in der beilage ist die leicht angepasste version, falls jemand das noch so brauchen möchte.
Dateianhänge
OrderCalc5-7_Vorlage.ods
(33.75 KiB) 117-mal heruntergeladen


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten