NEWS
Datenpunkt berechnen
-
Ich mach das in ungefähr so:
// Create Datenpunkte für kalkulierte Werte createState('javascript.0.Solar.Haus.VerbrauchL1', 0, {unit: "W", type: "number", role: "value"}); createState('javascript.0.Solar.Haus.VerbrauchL2', 0, {unit: "W", type: "number", role: "value"}); createState('javascript.0.Solar.Haus.VerbrauchL3', 0, {unit: "W", type: "number", role: "value"}); createState('javascript.0.Solar.Haus.Verbrauch', 0, {unit: "W", type: "number", role: "value"}); //Schedule Script Run Modbus Poll schedule("*/15 * * * * *", function (Haus){ log("Script Poll_Modbus; Trigger erhalten", "debug"); var Verbrauch = 0; //Verbrauch berechnen if (solar1.Inv1P01 > 0) { Verbrauch = solar1.Inv1P01; } else { Verbrauch = 0;} setState('javascript.0.Solar.Haus.VerbrauchL1', (Verbrauch + solar1.HausP01), true); if (solar1.Inv1P02 > 0) { Verbrauch = solar1.Inv1P02; } else { Verbrauch = 0;} setState('javascript.0.Solar.Haus.VerbrauchL2', (Verbrauch + solar1.HausP02), true); if (solar1.Inv1P03 > 0) { Verbrauch = solar1.Inv1P03; } else { Verbrauch = 0;} setState('javascript.0.Solar.Haus.VerbrauchL3', (Verbrauch + solar1.HausP03), true); setState('javascript.0.Solar.Haus.Verbrauch', (Inv1Import + solar1.HausPower), true); });
Habe da ordentlich weggekürzt fürs Beispiel, da ich die Daten in diesem Script auch noch erheben muss.
Es sollte aber das Prinzip zeigen. Die Berechunung des Geamtverbrauchs kann ich mir sparen, da ich am Zähler plus/minus Leistung ablese. Das ist quasi schon verrechnet.
-
Ich weiß nicht wie du die Daten vom Solarwechselrichter in ioBroker bekommst.
Mein "Problem" besteht darin, dass durch den Umweg vom Raspi über die CCU zurück zu ioBroker bei schnell wechselnder Sonneneinstrahlung tlw. kurzfristig falsche Verbrauchswerte berechnet werden.
Mit dem Parsen des Webinterfaces des Wechselrichters in ioBroker komme ich im Moment noch nicht klar.
verbrauch = Bezug + Erzeugung - Lieferung `
Mein Zähler liefert zwar namentlich den Bezug, der kann aber auch negativ sein und enthält daher bereits die Lieferung. Ich nenne den Punkt daher lieber Bilanz.Zu dieser Bilanz addiere ich den Solarertrag (doppeltes - !)
und gut ist, ich mache das über Blockly.
Gruß
Rainer
-
Ich weiß nicht wie du die Daten vom Solarwechselrichter in ioBroker bekommst. `
Modbus.````
//Schedule Script Run Modbus Poll~~@Homoran:~~ > Mein "Problem" besteht darin, dass durch den Umweg vom Raspi über die CCU zurück zu ioBroker bei schnell wechselnder Sonneneinstrahlung tlw. kurzfristig falsche Verbrauchswerte berechnet werden. ` Wie bekommst Du die Werte in die CCU ?
-
Hallo Paul,
ich hätte nur gerne einen Schubs in die Richtung, in die ich gehen muss.
Wenn ich an einem realen Beispiel mit einem gewissen "Leidensdruck" arbeite, denke ich kann ich besser lernen, als wenn man nur etwas abtippt.
Modbus. `
nein, höchstens S0Piko 5.5
Wie bekommst Du die Werte in die CCU ? `
Damals auch mit cut and paste (Das muss ein Ende haben )als shell-script auf dem Pi/Cubie…
#!/bin/bash # http://homematic-forum.de/forum/viewtopic.php?p=131956#p131956 # # define common parameters for wget # COMMONWGETARGS="-q -O - --timeout=10" wget $COMMONWGETARGS --http-user=USERNAME --http-password=MySecurePassword "http://192.168.138.54/index.fhtml" | sed -e "s/nbsp/nbsp;/g" | sed -e "s/nbsp;;/nbsp;/g" | sed -e "s/\ //g" | html2text | tr -s " \t\r\n" | sed -e "s/^ //" | sed -e "s/x x x/0/g" >/tmp/power-inverter1.values PHOTOVOLTAICS_DC1U=$( cat /tmp/power-inverter1.values | grep Spannung | head -1 | cut -f2 -d" " ) PHOTOVOLTAICS_DC2U=$( cat /tmp/power-inverter1.values | grep Spannung | head -2 | tail -1 | cut -f2 -d" " ) PHOTOVOLTAICS_DC1I=$( cat /tmp/power-inverter1.values | grep Strom | head -1 | cut -f2 -d" " | awk '{printf "%d\n",$1*1000}' ) PHOTOVOLTAICS_DC2I=$( cat /tmp/power-inverter1.values | grep Strom | head -2 | tail -1 | cut -f2 -d" " | awk '{printf "%d\n",$1*1000}' ) PHOTOVOLTAICS_DC1P=$(( $PHOTOVOLTAICS_DC1U * $PHOTOVOLTAICS_DC1I / 1000 )) PHOTOVOLTAICS_DC2P=$(( $PHOTOVOLTAICS_DC2U * $PHOTOVOLTAICS_DC2I / 1000 )) PHOTOVOLTAICS_ACCURP=$( cat /tmp/power-inverter1.values | grep aktuell | cut -f2 -d" " ) PHOTOVOLTAICS_ACTOTP=$( cat /tmp/power-inverter1.values | grep Gesamtenergie | cut -f5 -d" " ) PHOTOVOLTAICS_DAILYP=$( cat /tmp/power-inverter1.values | grep Tagesenergie | cut -f2 -d" " ) # # update the system variables in the HomeMatic # wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.DC1&value=$PHOTOVOLTAICS_DC1P" wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.DC2&value=$PHOTOVOLTAICS_DC2P" wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.AC&value=$PHOTOVOLTAICS_ACCURP" wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.DAILYP&value=$PHOTOVOLTAICS_DAILYP" wget $COMMONWGETARGS "http://192.168.138.52/addons/db/state.cgi?item=PV.TOTP&value=$PHOTOVOLTAICS_ACTOTP"
Davon verstehe ich auch nichts.
Inzwischen habe ich es mit node-red hinbekommen die Website mit den Credentials aufzurufen und den Quelltext herunterzuladen,
auch ein split nachbrachte schon mal einige brauchbare Blöcke.
Hier fehlt mir im Moment die Weiterverarbeitung von Arrays.
Danke für deine Hilfe
Rainer
-
solardaten in iobroker => 2. ir sensor von volkszähler, und iobroker 2. instanz von smartmeter
1342_bildschirmfoto_2017-02-19_um_17.59.54.png -
@Homoran; Hab zwar nicht den ganzen Artikel gelesen. aber hat nicht Paul schon hier: http://forum.iobroker.net/viewtopic.php … 5.5#p48206 das Script in JS übersetzt?
Geht das nicht?
-
aber hat nicht Paul schon hier: viewtopic.php?f=21&t=4888&p=48710&hilit=Piko+5.5#p48206 das Script in JS übersetzt? `
Das ist die Nach-Nachfolger Firmware. Dagegen sieht meine aus wie DOS im Vergleich zu Win10Gruß
Rainer
-
An dem shell script sehe ich, dass offenbar die Daten aus der Datei "/tmp/power-inverter1.values" geholt werden und mit grep gesucht wird.
Zur Anregung: In Javacsript kann man https://github.com/ioBroker/ioBroker.javascript#readfile und falls es eine Textdatei ist, mit https://wiki.selfhtml.org/wiki/JavaScript/Objekte/String/indexOf im Text suchen und mit https://wiki.selfhtml.org/wiki/JavaScript/Objekte/String/substr Teilzeichenketten ermitteln.
-
Hallo Paul,
dass offenbar die Daten aus der Datei "/tmp/power-inverter1.values" geholt werden und mit grep gesucht wird. `
da werden sie in Zeile 8 erst einmal hingeschriebenfalls es eine Textdatei ist, `
leider nein, ist eine HTML-Datei.! ````
! <title>PV Webserver</title>
! <form method="post" action="">
! | |
! | |PIKO 5.5
! Helios (255)
|
|
! |! * * *
! |
! | |
! |AC-Leistung |
|Energie |
! | |
! |aktuell |
x x x |
W |Gesamtenergie |
23117 |
kWh |
|! | |
! ||
|
|Tagesenergie |
7.47 |
kWh |
|! | |
! |Status |
Aus |
|! | |
! |
! |! * * *
! |
! | |
! |
! |PV-Generator |
|Ausgangsleistung |
|
|! | |
! |<u>String 1</u> |
|
|<u>L1</u> |
|
|
|! |
Spannung |
x x x |
V |Spannung |
x x x |
V |
|! | |
! |Strom |
x x x |
A |Leistung |
x x x |
W |
|! | |
! |<u>String 2</u> |
|
|<u>L2</u> |
|
|
|! |
Spannung |
x x x |
V |Spannung |
x x x |
V |
|! | |
! |Strom |
x x x |
A |Leistung |
x x x |
W |
|! | |
! |<u>String 3</u> |
|
|<u>L3</u> |
|
|
|! |
Spannung |
x x x |
V |
Spannung |
x x x |
V |
|! | |
! |Strom |
x x x |
A |
Leistung |
x x x |
W |
|! | |
! |
! | |! * * *
! |
! | |
! |
! | |
RS485 Kommunikation |
! | |
! | |
Wechselrichter |
| |
! * * *
! | |
! | |Einstellungen ! </form>
! ````im shellscript wird die anscheinend mit dem Paket html2text in Text umgewandelt (?)
Das nach dem o.a. Split herausgegebene zweite Elemet des Arrays, enthält die aktuelle Stromproduktion:
msg.payload : string[116] "↵ aktuell↵↵ x x x ↵ W↵"
Jetzt nur noch x x x, da ich meine Lunarmodule noch nicht montiert habe
Gruß
Rainer
-
@homoran: wenn du es mit node-red machen möchtest, lade die html Datei hoch, die du parsen willst.
-
Siehe im letzten post im Spoiler
Gruß
Rainer
-
Das wär ja die Paradeaufgabe für den Parser Adapter. Blöd sprech ich kein RegEx..
-
Das wär ja die Paradeaufgabe für den Parser Adapter. Blöd sprech ich kein RegEx.. `
Damit habe ich es auch nicht hinbekommen
Gruß
Rainer
-
da werden sie in Zeile 8 erst einmal hingeschrieben `
Oh, das habe ich übersehen :shock: Dann sollte man sich den Umweg über die Datei sparen und die HTML-Seite direkt einlesen (https://www.npmjs.com/package/request). -
Oh, das habe ich übersehen Dann sollte man sich den Umweg über die Datei sparen und die HTML-Seite direkt einlesen (request). `
und mit dem request-Block in Blockly habe ich es auch nicht hinbekommen, da kam nichts zurückDann muss ich es auf die Harte Tour mit dem "echten" js versuchen.
Danke erstmal für alles
Rainer
-
Um die Auswertung zu vereinfachen, sollte HTML in Text gewandelt werden, wozu das NPM-Modul "https://www.npmjs.com/package/html2plaintext" dienen kann, das in die Konfiguration der JS-Adapter-Instanz eingetragen werden muss.
-
Der flow liefert ein Array mit allen Werten.
! [
! {
! "id": "1f5df07c.81145",
! "type": "tab",
! "label": "Flow 5"
! },
! {
! "id": "12035f81.de82c",
! "type": "html",
! "z": "1f5df07c.81145",
! "name": "",
! "tag": "[bgcolor="#FFFFFF"]",
! "ret": "text",
! "as": "single",
! "x": 592,
! "y": 334,
! "wires": [
! [
! "dd0ca08d.c45bd"
! ]
! ]
! },
! {
! "id": "d487fa3f.daea58",
! "type": "inject",
! "z": "1f5df07c.81145",
! "name": "",
! "topic": "",
! "payload": " <title>PV Webserver</title>
! <form method=""post"" action="""">
! | |
| | PIKO 5.5
Helios (255) | |
! | |
! * * *! ! AC-Leistung Energie aktuell x x x W Gesamtenergie 23117 kWh Tagesenergie 7.47 kWh Status Aus ! ! * * *
! ! PV-Generator Ausgangsleistung <u>String 1</u> <u>L1</u> Spannung x x x V Spannung x x x V Strom x x x A Leistung x x x W <u>String 2</u> <u>L2</u> Spannung x x x V Spannung x x x V Strom x x x A Leistung x x x W <u>String 3</u> <u>L3</u> Spannung x x x V Spannung x x x V Strom x x x A Leistung x x x W ! ! * * *
! |
| |
! |
! | | RS485 Kommunikation |
| |
| | Wechselrichter |
| |
! * * *
! | |
| | Historie Infoseite | Einstellungen | |
! </form>
! ",
! "payloadType": "str",
! "repeat": "",
! "crontab": "",
! "once": false,
! "x": 376,
! "y": 331,
! "wires": [
! [
! "12035f81.de82c"
! ]
! ]
! },
! {
! "id": "dd0ca08d.c45bd",
! "type": "debug",
! "z": "1f5df07c.81145",
! "name": "",
! "active": true,
! "console": "false",
! "complete": "true",
! "x": 833,
! "y": 334,
! "wires": []
! }
! ]
1803_clipboard03.jpg -
STOP!!
Danke!!
das sind genug Ansätze.
Der flow liefert ein Array mit allen Werten. `
Nur wie kann ich ein Array mit allen Werten bei node-js weiterverarbeiten.Da war ich ja schon mit dem split node und kam nicht weiter.
Habe jetzt genug zu tüfteln
Danke erstmal an alle Helfer.
Gruß
Rainer
-
Rainer, nur damit wir mit-tüfteln können.
Kannst Du ein Beispiel machen, was genau anstelle x x x
dort steht. Sind das drei Werte für zB 3 Phasen oder was genau?
-
Habe erst einmal mit dem node angefangen.
Das ist doch nicht dein Ernst. :lol: :lol:
Warum kannte ich diesen node nicht:
` > Extracts elements from an html document held in msg.payload using a selector.If left blank the selector may be set dynamically by passing in msg.select along with the msg.payload.
The selector uses Cheerio which uses the CSS selector syntax.
The result can be either a single message with a payload containing an array of the matched elements, or multiple messages that each contain a matched element. `
kein Split, kein Regex, kein match
Sieht gut aus! aber was nun.
Wie kann ich (in node-red) mit einem Array weiterarbeiten.
Gruß
Rainer