Zahlenformat setzen

Programmierung unter AOO/LO (StarBasic, Python, Java, ...)

Moderator: Moderatoren

Benutzeravatar
lorbass
********
Beiträge: 4116
Registriert: Mo, 01.05.2006 21:29
Wohnort: Bonn

Re: Zahlenformat setzen

Beitrag von lorbass »

Michael Dannenhöfers StarBasic / OpenOffice.org Basic FAQ:
7.1.22 Wie kann man das Zahlenformat auf Standardformate einstellen?

Gruß
lorbass
Toxitom
********
Beiträge: 3768
Registriert: Di, 12.08.2003 18:07
Wohnort: Wiesbaden
Kontaktdaten:

Re: Zahlenformat setzen

Beitrag von Toxitom »

Hey wonkwonk,

der Fehler liegt wahrscheinlich im falsch übergebenen Format-String. Du darfst nicht die Variante des UI verwenden!

Code: Alles auswählen

NumberFormatId = NumberFormats.addNew("0,000", LocalSettings)    '1 Dezimalen
müsste wahrscheinlich heissen:

Code: Alles auswählen

NumberFormatId = NumberFormats.addNew("0.000", LocalSettings)    '1 Dezimalen
Bevor Du so etwas verwendest, kannst Du Dir doch den entsprechenden Formatstring erzeugen lassen:

Code: Alles auswählen

msgbox NumberFormats.generateFormat(1,LocalSettings, true, false, 0, 4)
Die Methode erwartet 6 Parameter - siehe auch API com.sun.star.util.XNumberFormat -> generateFormat.

Das Ergebnis ist: "0.000". Setze ich den bei Dir ein und lasse mir den Formatcode ausgeben (msgbox), so kommt bei mir 10170 als Code.

Im übrigen solltest Du immer vorher abfragen, ob der Code nicht bereits existiert - ein zweites Mal lässt er sich nicht einfügen - gibt immer eine Fehlermeldung.

Also zuerst:

Code: Alles auswählen

msgbox NumberFormats.queryKey("0.000", LocalSettings,true)
Liefert die Code-Index bzw. -1, falls es diesen Code nicht gibt.

Und dann klappt es auch mit der Zuordnung ;)

Viele Grüße
Tom
Unterstützer LibreOffice, zertifizierter Trainer und Berater
Bücher: LibreOffice 6- Einstieg und Umstieg
Makros Grundlagen - LibreOffice / OpenOffice Basic
Antworten