❤️ Helfen Sie noch heute, unser LibreOffice Forum zu erhalten! ❤️
Unterstützen Sie das LibreOffice-Forum und helfen Sie uns, unser Ziel für 2025 zu erreichen!

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱


❤️ 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. 🤗

DatumString umwandeln

Alles zur Programmierung im LibreOffice.
Antworten
bugfisch
Beiträge: 17
Registriert: So 12. Apr 2020, 19:23

DatumString umwandeln

Beitrag von bugfisch » Do 21. Aug 2025, 22:10

Hallo liebe Fans von Libre-Office,
was jahrelang funktioniert hatte, läuft jetzt plötzlich nicht mehr - da habe ich jetzt plötzlich mehrere Baustellen.

Folgende Umsetzung brennt mir z.B. unter den Nägeln und ich finde keine Lösung:

Ich habe ein String-Feld in einem Calc-Formular welches ein Datum in der Form 21.08.2025 enthält. Nun möchte ich den String umwandeln und einer anderen String-Variablen zuweisen in folgender Form: 20250821

Bis zu einer der letzten LibreOffice-Versionen ging das folgendermaßen:
ergebnisstring=Format(Formularfeld.string,"YYYMMDD")

Vielen Dank für eure Hilfe
Frank
Win11 64bit /Linux Debian bookworm

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

Re: DatumString umwandeln

Beitrag von karolus » Fr 22. Aug 2025, 06:11

Hallo
Machs halt vernünftig, mit python:

Code: Alles auswählen

from datetime import datetime as dt

input = "21.08.2025"
output = f"{dt.strptime( input , '%d.%m.%Y'):%Y%m%d}"
print(output)
LO25.2.x.y debian 13(trixie) auf Raspberry5 8GB (64bit)
LO25.8.x.y flatpak debian 13(trixie) auf Raspberry5 8GB (64bit)

bugfisch
Beiträge: 17
Registriert: So 12. Apr 2020, 19:23

Re: DatumString umwandeln

Beitrag von bugfisch » Fr 22. Aug 2025, 07:40

Vielen Dank für diesen Lösungsvorschlag. Die Programme sind in LibreOffice seit über 10 Jahren gewachsen - mit paar tausend Programmzeilen. Das ist nicht so schnell umzustellen.
Python wäre natürlich super - nutze ich für die Programmierung auf dem RaspberryPi.
Gruß
Win11 64bit /Linux Debian bookworm

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

Re: DatumString umwandeln

Beitrag von karolus » Fr 22. Aug 2025, 08:08

bugfisch hat geschrieben:
Fr 22. Aug 2025, 07:40
mit paar tausend Programmzeilen. Das ist nicht so schnell umzustellen.
Python wäre natürlich super - nutze ich für die Programmierung auf dem RaspberryPi.
Gruß
Letzteres mach ich auch und auch im Kontext von Libreoffice.
Falls du noch weisst was du da mal in den letzten 10 Jahren gemacht hast, und du ebenfalls in python nicht nur »copy&paste« beherrscht, dann ist JETZT der Zeitpunkt gekommen den alten Kram umzustellen.
LO25.2.x.y debian 13(trixie) auf Raspberry5 8GB (64bit)
LO25.8.x.y flatpak debian 13(trixie) auf Raspberry5 8GB (64bit)

bugfisch
Beiträge: 17
Registriert: So 12. Apr 2020, 19:23

Re: DatumString umwandeln

Beitrag von bugfisch » Sa 23. Aug 2025, 21:12

Hallo karolus,
leider hat mich die Antwort: "machs halt mit Python" jetzt doch nicht weiter gebracht wenn ich "noch" in Basic programmiere. Ich benötige die Lösung in Tagen und alles auf Python umzustellen wären Monate.
Habe die Sache folgendermaßen gelöst:

go_adbcell.String = mid(go_ordercell.string,7 ,4) + mid(go_ordercell.string,4 ,2) + mid(go_ordercell.string,1,2)

Danke aber!
Win11 64bit /Linux Debian bookworm

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

Re: DatumString umwandeln

Beitrag von mikele » So 24. Aug 2025, 21:08

Hallo,
ich habe es mal versucht unter LO 25.2.4.3 nachzustellen.
Folgendes funktioniert und liefert den gewünschten String:

Code: Alles auswählen

	s=Format(date,"YYYYMMDD")
Die Funktion Format() erwartet einen numerischen Ausdruck. Einen Datumsstring in einen anderen zu wandeln ist damit nicht möglich.

Code: Alles auswählen

format("24.08.2025","YYYYMMDD"))
geht schief.

Code: Alles auswählen

format(cdate(tmp),"YYYYMMDD")
wäre eine Alternative.
Ergänzung: In früheren Versionen, bei mir 7.3.7.2, wird auch

Code: Alles auswählen

format("24.08.2025","YYYYMMDD"))
akzeptiert, obwohl auch damals schon in der Hilfe stand:
Funktion Format
Wandelt einen numerischen Ausdruck in eine Zeichenfolge um und formatiert diese dann entsprechend dem von Ihnen angegebenen Format.
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