NEWS
Scriptanfänger braucht nochmal Hilfe
-
Hallo, ich versuche mich gerade mal wieder daran mir ein Script zu basteln, komme aber im moment nicht weiter.
Ich suche mir immer alles aus vorhandenen Scripten raus, daher bitte nicht zu sehr schimpfen wenn da unnötige Sachen mit drin sind
Mein Plan ist mir die nächsten 2 Termine als json anzeigen zu lassen, nur mit Event und Startzeit.
Leider schaffe ich es nicht und brauche eure Hilfe!
Es wird mir im Date das Datum und die Sart- und Endzeit angezeigt, da möchte ich nur die Startzeit stehen haben.
Hier mein Script
`var idCal = "ical.0"; var idCalTrigger = idCal + ".data.trigger"; var idCalTable = idCal + ".data.table"; var idCalHTML = idCal + ".data.html"; var idCalHTMLtable = idCal + "_1.json"; createState(idCalHTMLtable, " "); function iCalToHTMLTable() { var json = "["; var calTable = getState(idCalTable); var inst = getObject("system.adapter."+idCal); var instopt = inst.native; var calendar = {}; for (var i = 0; i < 2; i++) { var entry = calTable.val[i]; if ( entry._calName != calendar.name ) { calendar = {}; for (var c = 0; c < instopt.calendars.length; c++ ) { if (entry._calName == instopt.calendars[c].name ) { calendar = instopt.calendars[c]; break; } } } json +="{\"Event\":\""+entry.event+"\"," json +="\"Date\":\""+entry.date+"\"}," } json=json.substr( 0, json.length-1 ) + ']'; setState(idCalHTMLtable, json); //dump( html ); } on({id: idCalTable, change: "ne"}, function (obj) { iCalToHTMLTable(); }); schedule("5,35 * * * *", function () { iCalToHTMLTable(); }); iCalToHTMLTable();` Das Ergebnis sieht so aus: `~~[code]~~[{"Event":"Spätschicht","Date":"28.01.2019 13:30-22:00"},{"Event":"Tanja Arbeiten","Date":"28.01.2019 14:00-20:00"}][/code]`[/i]
-
Aus
json +="\"Date\":\""+entry.date+"\"},"
json +="\"Date\":\""+entry.date.split("-")[0]+"\"},"
machen
-
Aus
json +="\"Date\":\""+entry.date+"\"},"
json +="\"Date\":\""+entry.date.split("-")[0]+"\"},"
machen `
Danke, damit bin ich 1 Schritt weiter, die Endzeit ist weg, aber wie bekomme ich das Datum vorne noch weg?
[{"Event":"Spätschicht","Date":"28.01.2019 13:30"},{"Event":"Tanja Arbeiten","Date":"28.01.2019 14:00"}]
-
Aus
json +="\"Date\":\""+entry.date+"\"},"
json +="\"Date\":\""+entry.date.split("-")[0]+"\"},"
machen `
Danke, damit bin ich 1 Schritt weiter, die Endzeit ist weg, aber wie bekomme ich das Datum vorne noch weg?
[{"Event":"Spätschicht","Date":"28.01.2019 13:30"},{"Event":"Tanja Arbeiten","Date":"28.01.2019 14:00"}] ```` `
Bitte doch ein wenig mitdenken Ist nun wirklich nicht mehr schwer.
var date = entry.date.split("-")[0]; date = date.split(" ")[1]; json +="\"Date\":\""+date+"\"},"
-
Vielen Dank!!! Hatte irgendwie ein Brett vorm Kopf!
-
Habe nochmal alles umgeschmissen und möchte die Daten jetzt als einzelne Datenpunkte und nicht mehr in einer json ablegen. Aber aus einem Grund den ich nicht nachvollziehen kann, klappt irgendwas beim splitten nicht richtig
Hier der ausschnitt aus dem Script
... event += entry.event + "," date += entry.date + "," } var event1 = event.split(",")[0] var event2 = event.split(",")[1] var date1 = date.split(",")[0] var date2 = date.split(",")[1] ... setState('Schicht.Tanja', TanjaArbeiten); setState('Schicht.Torsten', TorstenArbeiten); setState('Test.event1', event1); setState('Test.event2', event2); setState('Test.date1', date1); setState('Test.date2', date2); setState('Test.event', event); setState('Test.date', date); ...
Die setState sind nur zur Fehleranalyse!
Mein Problem ist folgendes:
Warum wird bei event2 Spätschicht angezeigt und nicht Tanja Arbeiten? Bei date klappt es ja!
-
Sieht auch erstmal korrekt aus. Außer, dass eine Menge ";" am Ende fehlen.
Mal folgendes probieren, dann schauen wir erstmal, was drinsteht.
Da du den Code gekürzt hast weiss ich ja nicht, ob noch was anderes dazwischen steht, was dann zu Problemen führt.
event += entry.event + ","; date += entry.date + ","; var event1 = event.split(",")[0]; var event2 = event.split(",")[1]; var date1 = date.split(",")[0]; var date2 = date.split(",")[1]; console.log(event); console.log(event1); console.log(event2); console.log(date); console.log(date1); console.log(date2);
-
Im log sieht es gut aus
Aber in den Objekten unverändert
-
Dann ist irgendwas dazwischen, was es noch ändert.
-
Hier mal das gesamte Script mit dem ganzen "Müll", vielleicht siehst du da was ich übersehe
`var idCal = "ical.0"; var idCalTrigger = idCal + ".data.trigger"; var idCalTable = idCal + ".data.table"; var idCalHTML = idCal + ".data.html"; var idCalHTMLtable = idCal + "_1.json"; createState('Schicht.Tanja', " "); createState('Schicht.Torsten', " "); createState('Test.event1', " "); createState('Test.event2', " "); createState('Test.date1', " "); createState('Test.date2', " "); createState('Test.event', " "); createState('Test.date', " "); function iCalToHTMLTable() { var TanjaArbeiten = ""; var TorstenArbeiten =""; var calTable = getState(idCalTable); var inst = getObject("system.adapter."+idCal); var instopt = inst.native; var calendar = {}; var event / var date = "" for (var i = 0; i < 2; i++) { var entry = calTable.val[i]; if ( entry._calName != calendar.name ) { calendar = {}; for (var c = 0; c < instopt.calendars.length; c++ ) { if (entry._calName == instopt.calendars[c].name ) { calendar = instopt.calendars[c]; break; } } } event += entry.event + "," date += entry.date + "," } var event1 = event.split(",")[0]; var event2 = event.split(",")[1]; var date1 = date.split(",")[0]; var date2 = date.split(",")[1]; console.log(event); console.log(event1); console.log(event2); console.log(date); console.log(date1); console.log(date2); if (event1 = "Tanja Arbeiten") { TanjaArbeiten = date1 } if (event1 = "Spätschicht") { TorstenArbeiten = date1 } if (event2 = "Tanja Arbeiten") { TanjaArbeiten = date2 } if (event2 = "Spätschicht") { TorstenArbeiten = date2 } setState('Schicht.Tanja', TanjaArbeiten); setState('Schicht.Torsten', TorstenArbeiten); setState('Test.event1', event1); setState('Test.event2', event2); setState('Test.date1', date1); setState('Test.date2', date2); setState('Test.event', event); setState('Test.date', date); } on({id: idCalTable, change: "ne"}, function (obj) { iCalToHTMLTable(); }); schedule("5,35 * * * *", function () { iCalToHTMLTable(); }); iCalToHTMLTable();`[/i]
-
Sicher, dass du in das richtige Objekt guckst?
Schau mal unter javascript.0, steht da nochmal Test.event2?
//edit: Es fehlen immernoch ein Haufen ";" am Ende. Jede Zeile muss mit einem ";" enden.
-
sieht so aus
-
Dann schau doch mal da rein..
-
Das ist ja der Ordner, wo ich reinschaue, siehe Post => viewtopic.php?f=21&t=21447&p=225846#p225831
-
Das ist ja der Ordner, wo ich reinschaue, siehe Post => viewtopic.php?f=21&t=21447&p=225846#p225831 `
EDIT: habe jetzt in allen Zeilen, ausser wo ein { ist, ein ; gesetzt. Bleibt aber bei dem Problem
-
Habs.
Mach mal aus dem "=" ein "=="..
if (event1 == "Tanja Arbeiten") { TanjaArbeiten = date1 } if (event1 == "Spätschicht") { TorstenArbeiten = date1 } if (event2 == "Tanja Arbeiten") { TanjaArbeiten = date2 } if (event2 == "Spätschicht") { TorstenArbeiten = date2 }
-
Habs.
Mach mal aus dem "=" ein "==".. `
Ja, hatte gerade auch herausgefunden, dass es an diesen Zeilen liegt, aber nicht warum! Danke für die Hilfe!!
-
Ein "=" ist eine Zuweisung. z.B. var Variable = Wert;
Ein "==" ist ein Vergleichsoperator.