Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Kommazahl 0 anhängen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.7k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Kommazahl 0 anhängen

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascript
11 Beiträge 5 Kommentatoren 703 Aufrufe 4 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • M Offline
    M Offline
    Malaus
    schrieb am zuletzt editiert von
    #1

    Hallo Ihr,

    ich lese eine Temperatur aus und erhalte diesen Wert ohne Kommazahl.
    Wie kann ich bei diesem Wert eine Null anhängen?
    Heißt, bei 23 -> 23.0

    let testzahl = 23;
    let x = testzahl.toFixed(2); 
    let y = parseFloat(x.replace(',','.'));
        
    console.log('testzahl string ' + x);
    console.log('testzahl number ' + y);
    
    

    Als Log:

    testzahl string 23.00
    testzahl number 23
    

    Leider funktioniert das nicht, wo liegt hier mein Fehler?

    1 Antwort Letzte Antwort
    0
    • arteckA Offline
      arteckA Offline
      arteck
      Developer Most Active
      schrieb am zuletzt editiert von arteck
      #2

      @malaus das eine ist ein string.. das andere ein number
      und das ist abhängig von der angegebenen Landesfprmatierung

      https://linuxhint.com/add-commas-number-javascript/

      mit parseFloat machst du aus dem x String ein number ..

      zigbee hab ich, zwave auch, nuc's genauso und HA auch

      M 1 Antwort Letzte Antwort
      0
      • arteckA arteck

        @malaus das eine ist ein string.. das andere ein number
        und das ist abhängig von der angegebenen Landesfprmatierung

        https://linuxhint.com/add-commas-number-javascript/

        mit parseFloat machst du aus dem x String ein number ..

        M Offline
        M Offline
        Malaus
        schrieb am zuletzt editiert von
        #3

        @arteck meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number. Aber leider werden hier die neu hinzugefügte Kommastellen nicht mitgenommen.

        In deinem Beispiel werden größere Zahlen als Kommazahlen umgewandelt.
        Ich habe mal folgendes ausprobiert.

        console.log("Example to add comma to number");
        const num = 57484;
        const numFor = Intl.NumberFormat('en-US');
        const new_for = numFor.format(num);
        console.log(new_for)
        

        Leider funktioniert dieses Beispiel nur bei größeren Zahlen. Wenn die Zahl 23 ist, erhalte ich als Ergebnis 23.
        Gebe ich 2300 ein, erhalte ich als Ergebnis 2,300

        mickymM F CodierknechtC 4 Antworten Letzte Antwort
        0
        • M Malaus

          @arteck meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number. Aber leider werden hier die neu hinzugefügte Kommastellen nicht mitgenommen.

          In deinem Beispiel werden größere Zahlen als Kommazahlen umgewandelt.
          Ich habe mal folgendes ausprobiert.

          console.log("Example to add comma to number");
          const num = 57484;
          const numFor = Intl.NumberFormat('en-US');
          const new_for = numFor.format(num);
          console.log(new_for)
          

          Leider funktioniert dieses Beispiel nur bei größeren Zahlen. Wenn die Zahl 23 ist, erhalte ich als Ergebnis 23.
          Gebe ich 2300 ein, erhalte ich als Ergebnis 2,300

          mickymM Offline
          mickymM Offline
          mickym
          Most Active
          schrieb am zuletzt editiert von
          #4

          @malaus da in dem JavaScript Adapter auch JSONATA enthalten ist kannst Du über $formatNumber die Zahl in einen String umwandeln und mit picture das Ausgabeformat festlegen.

          http://docs.jsonata.org/numeric-functions

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          1 Antwort Letzte Antwort
          0
          • M Malaus

            @arteck meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number. Aber leider werden hier die neu hinzugefügte Kommastellen nicht mitgenommen.

            In deinem Beispiel werden größere Zahlen als Kommazahlen umgewandelt.
            Ich habe mal folgendes ausprobiert.

            console.log("Example to add comma to number");
            const num = 57484;
            const numFor = Intl.NumberFormat('en-US');
            const new_for = numFor.format(num);
            console.log(new_for)
            

            Leider funktioniert dieses Beispiel nur bei größeren Zahlen. Wenn die Zahl 23 ist, erhalte ich als Ergebnis 23.
            Gebe ich 2300 ein, erhalte ich als Ergebnis 2,300

            F Offline
            F Offline
            fastfoot
            schrieb am zuletzt editiert von
            #5

            @malaus

            const fmtDe = Intl.NumberFormat('en-US', {
                minimumIntegerDigits: 1,
                minimumFractionDigits: 1,
                maximumFractionDigits: 3
            });
            let number1 = 23.00001;
            let number2 = 23.12389;
            log(fmtDe.format(number1));
            log(fmtDe.format(number2));
            

            iobroker läuft unter Docker auf QNAP TS-451+
            SkriptRecovery: https://forum.iobroker.net/post/930558

            1 Antwort Letzte Antwort
            0
            • M Malaus

              @arteck meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number. Aber leider werden hier die neu hinzugefügte Kommastellen nicht mitgenommen.

              In deinem Beispiel werden größere Zahlen als Kommazahlen umgewandelt.
              Ich habe mal folgendes ausprobiert.

              console.log("Example to add comma to number");
              const num = 57484;
              const numFor = Intl.NumberFormat('en-US');
              const new_for = numFor.format(num);
              console.log(new_for)
              

              Leider funktioniert dieses Beispiel nur bei größeren Zahlen. Wenn die Zahl 23 ist, erhalte ich als Ergebnis 23.
              Gebe ich 2300 ein, erhalte ich als Ergebnis 2,300

              CodierknechtC Online
              CodierknechtC Online
              Codierknecht
              Developer Most Active
              schrieb am zuletzt editiert von
              #6

              @malaus sagte in Kommazahl 0 anhängen:

              Aber leider werden hier die neu hinzugefügte Kommastellen nicht mitgenommen

              Ein Trugschluss!
              Die "Kommastellen" sind sehr wohl enthalten. Sie werden ohne weiteres Zutun lediglich nicht dargestellt.
              Für die Darstellung (Vis oder Log) wird die Zahl implizit in einen String konvertiert. Nachkommastellen werden dabei nur dann mit ausgegeben, wenn man das explizit mit angibt.

              @malaus sagte in Kommazahl 0 anhängen:

              Gebe ich 2300 ein, erhalte ich als Ergebnis 2,300

              Auch das ist ein Trugschluss. Das "Komma" ist hier kein Komma, sondern das Tausender-Trennzeichen im angegebenen Länderformat (en-US).
              Wenn Du - wie in D/A/CH üblich - den Punkt als Tausender-Trennzeichen haben möchtest, musst Du das gewünschte Länderformat (de-DE) mit angeben.

              "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

              Proxmox 9.1.1 LXC|8 GB|Core i7-6700
              HmIP|ZigBee|Tasmota|Unifi
              Zabbix Certified Specialist
              Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

              1 Antwort Letzte Antwort
              0
              • mickymM Offline
                mickymM Offline
                mickym
                Most Active
                schrieb am zuletzt editiert von
                #7

                So ich habs gerade im JS Adapter getestet und JSONATA tut jedenfalls:

                7857e59c-047c-43ab-b197-6267b5d796c8-image.png

                console.log(jsonataExpression(23,'$formatNumber($, "0,00",{\'decimal-separator\':\',\'})'));
                

                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                M 1 Antwort Letzte Antwort
                0
                • mickymM mickym

                  So ich habs gerade im JS Adapter getestet und JSONATA tut jedenfalls:

                  7857e59c-047c-43ab-b197-6267b5d796c8-image.png

                  console.log(jsonataExpression(23,'$formatNumber($, "0,00",{\'decimal-separator\':\',\'})'));
                  
                  M Offline
                  M Offline
                  Malaus
                  schrieb am zuletzt editiert von
                  #8

                  @mickym wenn ich das ausführe, erhalte ich wieder einen String?
                  Wie wäre das, wenn ich das dann in eine Number schreiben möchte?

                  mickymM 1 Antwort Letzte Antwort
                  0
                  • M Malaus

                    @arteck meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number. Aber leider werden hier die neu hinzugefügte Kommastellen nicht mitgenommen.

                    In deinem Beispiel werden größere Zahlen als Kommazahlen umgewandelt.
                    Ich habe mal folgendes ausprobiert.

                    console.log("Example to add comma to number");
                    const num = 57484;
                    const numFor = Intl.NumberFormat('en-US');
                    const new_for = numFor.format(num);
                    console.log(new_for)
                    

                    Leider funktioniert dieses Beispiel nur bei größeren Zahlen. Wenn die Zahl 23 ist, erhalte ich als Ergebnis 23.
                    Gebe ich 2300 ein, erhalte ich als Ergebnis 2,300

                    mickymM Offline
                    mickymM Offline
                    mickym
                    Most Active
                    schrieb am zuletzt editiert von
                    #9

                    @malaus sagte in Kommazahl 0 anhängen:

                    ....meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number.

                    Sobald Du etwas wieder in eine Zahl zurückverwandeltst, dann verlierst Du die Formatierung. Intern werden Zahlen nicht mit 0 hinter dem Komma gerechnet und Dezimaltrenner sind nun mal Punkte und kein Komma. Entweder Du wandelst eine Zahl in einen String um, um das darzustellen, aber Du wirst JS nicht dazu bringen Dezimalzahlen mit Komma als Zahlen zu akzeptieren. Deswegen ist das Zurückkonvertieren in Number völlig verkehrt.

                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                    M 1 Antwort Letzte Antwort
                    1
                    • mickymM mickym

                      @malaus sagte in Kommazahl 0 anhängen:

                      ....meine Idee war, dass ich die erhaltene Number mit toFixed() in ein String umwandle und zwei Kommastellen hinzufüge. Danach das ganze wieder zurück zu Number.

                      Sobald Du etwas wieder in eine Zahl zurückverwandeltst, dann verlierst Du die Formatierung. Intern werden Zahlen nicht mit 0 hinter dem Komma gerechnet und Dezimaltrenner sind nun mal Punkte und kein Komma. Entweder Du wandelst eine Zahl in einen String um, um das darzustellen, aber Du wirst JS nicht dazu bringen Dezimalzahlen mit Komma als Zahlen zu akzeptieren. Deswegen ist das Zurückkonvertieren in Number völlig verkehrt.

                      M Offline
                      M Offline
                      Malaus
                      schrieb am zuletzt editiert von
                      #10

                      @mickym danke für diese Info. Dann kann ich das lange probieren.

                      1 Antwort Letzte Antwort
                      0
                      • M Malaus

                        @mickym wenn ich das ausführe, erhalte ich wieder einen String?
                        Wie wäre das, wenn ich das dann in eine Number schreiben möchte?

                        mickymM Offline
                        mickymM Offline
                        mickym
                        Most Active
                        schrieb am zuletzt editiert von mickym
                        #11

                        hat sich überschnitten. ;)

                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                        1 Antwort Letzte Antwort
                        0
                        Antworten
                        • In einem neuen Thema antworten
                        Anmelden zum Antworten
                        • Älteste zuerst
                        • Neuste zuerst
                        • Meiste Stimmen


                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        287

                        Online

                        32.6k

                        Benutzer

                        82.3k

                        Themen

                        1.3m

                        Beiträge
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                        ioBroker Community 2014-2025
                        logo
                        • Anmelden

                        • Du hast noch kein Konto? Registrieren

                        • Anmelden oder registrieren, um zu suchen
                        • Erster Beitrag
                          Letzter Beitrag
                        0
                        • Home
                        • Aktuell
                        • Tags
                        • Ungelesen 0
                        • Kategorien
                        • Unreplied
                        • Beliebt
                        • GitHub
                        • Docu
                        • Hilfe