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.
  • 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 Offline
            CodierknechtC Offline
            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

                      324

                      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