🍀 Das LibreOffice Forum braucht HEUTE Ihre Hilfe! 🍀
❤️ Spenden Sie jetzt und sichern Sie die Zukunft unseres LibreOffice-Forums ❤️
Ihre Spende hilft, die Community offen, werbefrei (bei Registrierung) und lebendig zu halten. Vielen lieben Dank!
>> Das LibreOffice-Forum lebt von Ihnen – und von vielen Experten, die freiwillig und kostenlos ihr Wissen teilen.<<
Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet.
DatumString umwandeln
DatumString umwandeln
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
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
Re: DatumString umwandeln
Hallo
Machs halt vernünftig, mit python:
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)
LO25.8.x.y flatpak debian 13(trixie) auf Raspberry5 8GB (64bit)
Re: DatumString umwandeln
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ß
Python wäre natürlich super - nutze ich für die Programmierung auf dem RaspberryPi.
Gruß
Win11 64bit /Linux Debian bookworm
Re: DatumString umwandeln
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)
LO25.8.x.y flatpak debian 13(trixie) auf Raspberry5 8GB (64bit)
Re: DatumString umwandeln
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!
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
Re: DatumString umwandeln
Hallo,
ich habe es mal versucht unter LO 25.2.4.3 nachzustellen.
Folgendes funktioniert und liefert den gewünschten String:
Die Funktion Format() erwartet einen numerischen Ausdruck. Einen Datumsstring in einen anderen zu wandeln ist damit nicht möglich.
geht schief.
wäre eine Alternative.
Ergänzung: In früheren Versionen, bei mir 7.3.7.2, wird auch akzeptiert, obwohl auch damals schon in der Hilfe stand:
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")Code: Alles auswählen
format("24.08.2025","YYYYMMDD"))Code: Alles auswählen
format(cdate(tmp),"YYYYMMDD")Ergänzung: In früheren Versionen, bei mir 7.3.7.2, wird auch
Code: Alles auswählen
format("24.08.2025","YYYYMMDD"))Funktion Format
Wandelt einen numerischen Ausdruck in eine Zeichenfolge um und formatiert diese dann entsprechend dem von Ihnen angegebenen Format.
Gruß,
mikele
mikele
Re: DatumString umwandeln
Bei mir klappt es so:
Hoffe, es kommt nicht zu spät...
LG vom Martin
Code: Alles auswählen
MsgBox Format(CLng(CDate("24.08.2025")), "yyyyMMdd")LG vom Martin
An alle, die das LibreOffice-Forum gern nutzen:
Bitte beteiligen Sie sich mit 7 Euro pro Monat und helfen uns bei unserem Budget für das laufende.
Einfach per Kreditkarte oder PayPal. Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet.
❤️ Vielen lieben Dank für Ihre Unterstützung ❤️