NEWS
Cronjob immer letzter Tag im Monat
-
@nik82 Kann mir jemman sagen woher ich den Teil
-Datum/Zeit. --nach Monatsdatum bekomme- Gleich Zeichen (=)
finde diese beiden nicht im Blockly
-
-
@djmarc75 Danke, habs nun ist warten angesagt ob es klappt
-
Mit einem Rechtsklick auf, hier z.B. das = Zeichen, kannst Du bei fast jedem Baustein auf externe Eingänge umstellen.
Dann sieht der Block so aus
-
Ich will das Script immer am Monatsende um 22:00 laufen lassen. Ist das dann so richtig?
<block xmlns="https://developers.google.com/blockly/xml" type="schedule" id="e!o9;)h*kzJ[dQTHL6?o" x="-612" y="-1687"> <field name="SCHEDULE">0 22 L * *</field> <statement name="STATEMENT"> <block type="control" id="-W^h[+Rt6MgwZQSfi4V^"> <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation> <field name="OID">0_userdata.0.PV.Zähler_Monat</field> <field name="WITH_DELAY">FALSE</field> <value name="VALUE"> <block type="get_value" id=")C[2PEW2XJI@m8+0NNm."> <field name="ATTR">val</field> <field name="OID">sourceanalytix.0.goodwe__0__RunningData__PvEnergyTotal.currentYear.delivered.03_currentMonth</field> </block> </value> </block> </statement> </block>
-
@endurance sagte: Ist das dann so richtig?
Das im Javascript-Adapter verwendete "node-schedule" unterstützt es nicht.
Currently, W (nearest weekday) and L (last day of month/week) are not supported.
-
@nik82 sagte in Cronjob immer letzter Tag im Monat:
Hi, vielen Dank für deine Rückantwort, das wäre natürlich noch schöner wenn das funktioniert, ich kann das im Blockly zumindest reinschreiben, mal schauen Ende des Monats ob es funktioniert.
Danke!Wenn Du NodeRed und die cron-plus Node verwendest, die kann das. Oder auch mit Standardmitteln eine Change oder Switch Node, da hier die moments Bibliothek integriert ist.
Damit kann man mit endOf - immer das jeweilige Ende einer Zeiteinheit bestimmen: https://momentjs.com/docs/#/manipulating/end-of/
-
@endurance Alternativ könnte das auch per "exec" klappen:
schedule('{"time":{"start":"22:00","exactTime":true},"period":{"months":1,"dates":"[28,29,30,31]"}}', async function () { exec('[ $(date --date +1day +\%d) -eq 1 ] && iobroker state getplain system.adapter.admin.0.uptime | sed -n "1p"', function (error, stdout, stderr) { setState('0_userdata.0.uptime',stdout); }); });
Die Anweisung [ $(date --date +1day +%d) -eq 1 ] && ... führt den Befehl nach && nur aus, wenn heute plus ein Tag gleich eins ist - wenn morgen also der Erste ist.
Datenpunkte natürlich noch anpassen.
-
Hier nochmal das Script als Export, weil es gewünscht war:
Funktioniert bei mir einwandfrei.
-
Besten dank.
Ich werd daraus nicht ganz schlau, startet das Script nun am 28, 29, 30 und 31? Und das dann jeweils um 23:30 + 12 Stunden?
-
@endurance
Nein, das Script startet um 23:30 Uhr und prüft, ob der Tag in 12 Stunden zufälligerweise der 1. ist.
Dann ist ja der aktuelle Tag der letzte des Monats und die Verarbeitung soll durchgeführt werden.
Laufen muss das Script ja nur vom 28. bis zum 31. - denn nur an diesen Tagen besteht die Chance, dass der nächste Tag der 1. ist.