🙏 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. 🤗

Makros gehen nicht mehr

Alles zur Programmierung im LibreOffice.
Antworten
BritzFox
Beiträge: 11
Registriert: Fr 17. Mär 2017, 17:49

Makros gehen nicht mehr

Beitrag von BritzFox » Fr 18. Jul 2025, 19:48

Moin,
über Nacht gehen meine Makros zum Teil nicht mehr.
Das ist übel, weil ich schreibe damit Rechnungen.
Ich habe nichts installiert. Eventuell hat Win11 ein Update gemacht.
Ich habe eben mal LibreOffice 25.2.25 drüber installiert.
Vorher war 25.2.4

Ich kenne mich mit Makros nicht so gut aus.
Das Meiste hatte ich hier aus dem Forum.

Momentan kann ich kein neues Dokument öffnen, da kommt:

Code: Alles auswählen

Lesefehler.
Formatfehler in Teildokument styles.xml an Position 2,4158(Zeile,Spalte) in der Datei entdeckt.
und beim Vorlage speichern kommt

Code: Alles auswählen

BASIC-Laufzeitfehler.
'1'
Es ist eine Ausnahme aufgetreten 
Type: com.sun.star.task.ErrorCodeIOException
Message: SfxBaseModel::impl_store <file:///d:/daten/firma/rechnungen/vorlage/vorlage2016.ots> failed: 0x81a(Error Area:Io Class:Parameter Code:26).
Ist hier irgendwo ein Fehler zu sehen ?

Code: Alles auswählen

REM  *****  BASIC  *****

Rem Attribute VBA_ModuleType=VBADocumentModule
Option VBASupport 1
' Neue Datei öffnen ###################################################

Sub Form_oeffnen
 Dim vDoc 'die geladene Komponente
 Dim Arg() 'ein leeres Array der Argumenteliste
 Dim sURL as String, Sframe As String, lSearch As Long
 sUrl = convertToURL("d:\Daten\Firma\rechnungen\vorlage\vorlage2016.ots")
 vDoc=StarDesktop.loadComponentFromURL (sURL, "_blank", 63, Arg())

end sub

' Datum per Strg+9 ####################################################
Sub AktuellesDatumEinfuegen
'   thisComponent.CurrentSelection().setString(date())   
   thisComponent.CurrentSelection().setValue(date())   
End Sub

' Zeile füllen - geht nicht
sub setdate2
    oDoc = thisComponent
    Sheet = oDoc.Sheets(0) '[erstes Arbeitsblatt]
    mycell01 = Sheet.getCellRangeByName("$E$25")
    if mycell01.string = "" then
        mycell01.string = "Arbeitszeit " & date()
    end if
end sub

' Datei speichern unter M13 ###########################################
sub save2
  oDoc=thisComponent
  Sheet = oDoc.Sheets(0) '[erstes Arbeitsblatt]
  Cell = Sheet.getCellByPosition(12, 13)  '[Zelle A1]
  Filename = Cell.String
  dim args1(0) as new com.sun.star.beans.PropertyValue
  args1(0).Name = "FilterName"
  args1(0).Value = "calc8"

  arg = Array(com.sun.star.ui.dialogs.TemplateDescription.FILESAVE_AUTOEXTENSION)
  dialog = CreateUnoService("com.sun.star.ui.dialogs.OfficeFilePicker")
  'Hinweis: der Dialog "com.sun.star.ui.dialogs.FilePicker" hat einen Bug bei .DisplayDirectory
  '         deshalb muss hier der OO-eigene Dialog .OfficeFilePicker genutzt werden
  dialog.Initialize(arg())
  dialog.appendFilter( "ODF Tabellendokument (*.ods)", "*.ods" )
  dialog.SetMultiselectionMode(False)
  dialog.DisplayDirectory = ConvertToURL("D:\Daten\Firma\rechnungen\2025\")
  dialog.DefaultName = Filename
  ok = dialog.execute()
  if ok = 1 Then   
   datei = dialog.getFiles()
   URL = datei(0)
    oDoc.storeasurl(URL, args1())
  end if

end sub

' Datum einfügen######################################################################
sub setdate
 oDoc=thisComponent
 Sheet = oDoc.Sheets(0) '[erstes Arbeitsblatt]
 mycell01 = Sheet.getCellRangeByName("$M$11")
  if mycell01.string = "" then
 'Insert_As_Value( Date, "TT. MMM JJJJ", com.sun.star.util.NumberFormat.DATE )
  mycell01.value = date()
  end if
 'Text einfügen
    oDoc = thisComponent
    Sheet = oDoc.Sheets(0) '[erstes Arbeitsblatt]
    mycell01 = Sheet.getCellRangeByName("$E$25")
    if mycell01.string = "" then
        mycell01.string = "Arbeitszeit " & date()
    end if
end sub

' Vorlage speichern ##################################################################

sub savevorlage

msg = msgbox("Vorlage überschreiben ?",4)         
if msg = 6 then
  oDoc=thisComponent
  Sheet = oDoc.Sheets(0) '[erstes Arbeitsblatt]
  Filename = "vorlage2016"
   mycell01 = Sheet.getCellRangeByName("$M$11")
   mycell01.string = ""
   mycell02 = Sheet.getCellRangeByName("$E$25")
   mycell02.string = ""
  Path = "file:///d:/daten/firma/rechnungen/vorlage/" '[Pfad anpassen bei Windows]
  dim args1(0) as new com.sun.star.beans.PropertyValue
  args1(0).Name = "FilterName"
  args1(0).Value = "StarOffice XML (Calc)"
 
  oDoc.storeasurl(Path & Filename & ".ots",args1())
  end if
end sub

' PDF Drucken ########################################################################
sub DruckerX
 dim document as object
 dim dispatcher as object
 document = ThisComponent.CurrentController.Frame
 dispatcher = createUnoService("com.sun.star.frame.DispatchHelper")
 dim args1(0) as new com.sun.star.beans.PropertyValue
 args1(0).Name = "Printer"
 args1(0).Value = "FreePDF"
 dispatcher.executeDispatch(document, ".uno:Printer", "", 0, args1())
 dim args2(1) as new com.sun.star.beans.PropertyValue
 args2(0).Name = "Copies"
 args2(0).Value = 1
 args2(1).Name = "Collate"
 args2(1).Value = false
 dispatcher.executeDispatch(document, ".uno:Print", "", 0, args2())
end sub 


 
Kann mir bitte jemand helfen bei der Problemlösung ?

mikele
* LO-Experte *
Beiträge: 1932
Registriert: Mo 1. Aug 2011, 20:51

Re: Makros gehen nicht mehr

Beitrag von mikele » Sa 19. Jul 2025, 13:02

Hallo,
Formatfehler in Teildokument styles.xml
Das bedeutet, dass die zu öffnende Datei eine internen Fehler aufweist, den LO nicht auflösen kann. Wenn das bei einem neuen Dokument passiert, vermute ich, das die Dokumentvorlage defekt ist.
Magst du uns diese Datei hier zur Verfügung stellen?
Der andere Fehler scheint daher zu rühren, dass das angegebene Verzeichnis nicht exisitiert oder falsch geschrieben wurde.
Gruß,
mikele


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