Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Wie das Datumsformat in VIS2 eintragen?

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Wie das Datumsformat in VIS2 eintragen?

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 @Ben1983 last edited by paul53

      @ben1983 sagte: Nur macht er aus dem 04.01.2025 den 03.01.2025.

      Das glaube ich nicht: Der Monat muss vor dem Tag stehen, damit das Datum richtig interpretiert wird: "MM.DD.YYYY".

      Ben1983 1 Reply Last reply Reply Quote 0
      • Ben1983
        Ben1983 @paul53 last edited by

        @paul53 Aber du hast doch oben auch:

        formatDate(new Date('04.01.2025'),'DD.MM.YYYY'));
        stehen.

        Ich habe nun:

        formatDate(datumswert,"DD.MM.YYYY")
        

        und er spuckt bei Tag > 12 ein invalidDate aus. obwohl ja im format angegeben ist, dass zuerst date kommen soll:

        Visu: Start und ende:

        a8cd3f83-06df-4dab-90bb-ee3e6e67f515-image.png

        Ergebnis:

        a480ba7a-332d-459d-a517-bcf9c5373eb7-image.png

        1ab5b57d-9151-4f54-8e1b-48b601939076-image.png

        paul53 1 Reply Last reply Reply Quote 0
        • paul53
          paul53 @Ben1983 last edited by paul53

          @ben1983 sagte: du hast doch oben auch:

          formatDate(new Date('04.01.2025'),'DD.MM.YYYY'));

          ... und das Datum ergibt im Ergebnis den 01.04.2025.
          Die Ausgabe kann im Format "DD.MM.YYYY" erfolgen, aber nicht die Eingabe. Im Eingabe-String muss der Monat vor dem Tag stehen, damit richtig interpretiert wird.

          Ben1983 1 Reply Last reply Reply Quote 0
          • Ben1983
            Ben1983 @paul53 last edited by Ben1983

            @paul53
            OK. Also im log steht "2025-01-04"
            Das bedeutet für mich YYYY = 2025 ; MM = 01 ; DD = 04.
            nicht 01.05.2025 oder?

            und in der eingabe der visu kann man ja das format nicht ändern, das ist ja gerade mein "Problem".

            Das anzeigeformat "DD.MM.YYYY" finde ich ja gut, aber die new Date() funktion wohl nicht

            paul53 1 Reply Last reply Reply Quote 0
            • paul53
              paul53 @Ben1983 last edited by

              @ben1983 sagte: und in der eingabe der visu kann man ja das format nicht ändern.

              Du kannst den 4.1.2025 aber so eingeben: 01.04.2025. Also erst der Monat, dann der Tag.

              Ben1983 1 Reply Last reply Reply Quote 0
              • Ben1983
                Ben1983 @paul53 last edited by

                @paul53 Ja aber es ist ja ein fertiges widget.
                Man klickt auf einem Kalender ein datum an.

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Ben1983 last edited by paul53

                  @ben1983 sagte: Man klickt auf einem Kalender ein datum an.

                  Dann tausche Monat und Tag im Skript vor new Date():

                  var date = '04.01.2025';
                  date = date.split('.');
                  date = date[1] + '.' + date[0] + '.' + date[2]; 
                  // oder
                  // date = date[2] + '-' + date[1] + '-' + date[0];
                  
                  Ben1983 1 Reply Last reply Reply Quote 0
                  • Ben1983
                    Ben1983 @paul53 last edited by

                    @paul53 OK.
                    Versuche ich mal, aber wär es nicht sinnvoll die Ausgabe des Widgets eingeben zu können?

                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @Ben1983 last edited by

                      @ben1983 sagte: wär es nicht sinnvoll die Ausgabe des Widgets eingeben zu können?

                      So wird die Ausgabe des Widgets ("DD.MM.YYYY") richtig verarbeitet.

                      Ben1983 2 Replies Last reply Reply Quote 0
                      • Ben1983
                        Ben1983 @paul53 last edited by

                        @paul53 Also ich meinte damit schon so ausgeben, aber im Hintergrund die Variable entsprechend eines angegebenen formats beschrieben / auslesen

                        1 Reply Last reply Reply Quote 0
                        • Ben1983
                          Ben1983 @paul53 last edited by Ben1983

                          @paul53 Habe jetzt meine Funktion so umgeändert:

                          läuft:

                          function nowIsBetweenCompleteDate(startdate, enddate){
                              let temp = startdate.split(".");
                              startdate = `${temp[2]}-${temp[1]}-${temp[0]}`;
                              temp = enddate.split(".");
                              enddate = `${temp[2]}-${temp[1]}-${temp[0]}`;
                              const today = new Date();
                              const start = new Date(startdate);
                              const end = new Date(enddate);
                              start.setHours(0);
                              start.setMinutes(0);
                              start.setSeconds(0);
                              end.setHours(23);
                              end.setMinutes(59);
                              end.setSeconds(59);
                              return (today >= start && today <= end);
                          }
                          

                          Allerdings liegt jetzt der string immer noch "falsch" im dp. und wenn drauf zugegriffen wird, dann kommt es zu einem fehler, also mussi ch es anders lösen

                          Codierknecht 1 Reply Last reply Reply Quote 0
                          • Codierknecht
                            Codierknecht Developer Most Active @Ben1983 last edited by

                            @ben1983
                            Kann man übrigens auch schön per replace machen:

                            let start = new Date(startdate.replace(/(\d+)[.](\d+)[.](\d+)/,'$3-$2-$1'));
                            

                            Im Sinne von "CleanCode" würde ich persönlich auch strikt zwischen Parametern und lokalen Variablen trennen. Sonst kommt man da (später mal) schnell durcheinander. Soll heißen: Keine Parameter intern nochmals verändern.

                            1 Reply Last reply Reply Quote 0
                            • Ben1983
                              Ben1983 last edited by

                              Ich habe jetzt das Widget Input verwendet:

                              hier kann man das angeben:
                              Das macht auf der Eingabemaske: DD.MM.YYYY
                              gibt es aber als wert passend raus: YYYY-MM-DD

                              1 Reply Last reply Reply Quote 0
                              • First post
                                Last post

                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              873
                              Online

                              32.0k
                              Users

                              80.5k
                              Topics

                              1.3m
                              Posts

                              3
                              16
                              303
                              Loading More Posts
                              • Oldest to Newest
                              • Newest to Oldest
                              • Most Votes
                              Reply
                              • Reply as topic
                              Log in to reply
                              Community
                              Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                              The ioBroker Community 2014-2023
                              logo