Seite 1 von 1

Re: Zahlenformat setzen

Verfasst: Sa, 07.10.2017 19:36
von lorbass
Michael Dannenhöfers StarBasic / OpenOffice.org Basic FAQ:
7.1.22 Wie kann man das Zahlenformat auf Standardformate einstellen?

Gruß
lorbass

Re: Zahlenformat setzen

Verfasst: So, 08.10.2017 18:19
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