NEWS
UNSOLVED Daten aus Url abfragen und in Datenpunkt schreiben
-
Hallo,
ist es möglich von einer Url Daten abzufragen und einen Wert in einen Datenpunkt zu schreiben?
Ich habe einen Rasenmähroboter und möchte davon gerne die Qualität der Messer abfragen und diese in meiner Visualisierung anzeigen lassen.
Vielen Dank
-
@steff-h
Stichwort für Suche: request -
Beispiel für Javascript:
var request = require('request'); const link = "http://..."; request(link, function(error, response, body) { if (error) { log('Error from request:' + error, 'error'); } else { // do something with body } });
Als Beispiel hatte ich mal ein Script für die Abfrage des bitcoin erstellt:
if (getState("bitcoin").notExist) { createState("bitcoin", 0); } const link = "https://api.coinbase.com/v2/prices/spot?currency=EUR"; request(link, function(error, response, body) { if (error) log('Error from Coinbase API:' + error, 'error'); else { var result = JSON.parse(body); var amount = Number(result.data.amount); setState("bitcoin", amount.toFixed(0), true); } });
-
Und hier dann gleich noch ein Blockly.
Loglevel kann man natürlich ändern. War nur zum testen. Ebenso das letzte debug output war nur zum test um zu im log gucken wie der output aussieht. -
@cburghardt said in Daten aus Url abfragen und in Datenpunkt schreiben:
Ich habe noch eine Frage zu dem Skript, wie bekomme ich es denn hin, das der Kurs Wert z.B. alle 10 sek. aktualisiert wird ? Ich habe leider nicht so die große Ahnung von Java Skripten... und auch das Blockly von @el_malto durchblicke ich noch nicht so ganz....
Woher bekomme ich denn die genaue URL zum Kurs Wert der in Skript angezeigt werden soll ? Wenn ich jetzt z.B. einen anderen Wert von einer anderen URL einbinden möchte ?? mit dem Internet Browser den Quelltext untersuchen, und dann die Zeile mit dem Kurs Wert heraus suchen??? Sorry für die Frage, aber ich bin da noch nicht so fit
-
@martink said in Daten aus Url abfragen und in Datenpunkt schreiben:
Ich habe noch eine Frage zu dem Skript, wie bekomme ich es denn hin, das der Kurs Wert z.B. alle 10 sek. aktualisiert wird ? Ich habe leider nicht so die große Ahnung von Java Skripten...
Das machst du mit einer Zeitfunktion bzw. Cron (schedule). Kann JS wohl lesen, aber selber nicht "schreiben". Hoffe die Syntax passt so. Einfach mal testen:
if (getState("bitcoin").notExist) { createState("bitcoin", 0); } const link = "https://api.coinbase.com/v2/prices/spot?currency=EUR"; schedule("*/10 * * * * *", function () { request(link, function(error, response, body) { if (error) log('Error from Coinbase API:' + error, 'error'); else { var result = JSON.parse(body); var amount = Number(result.data.amount); setState("bitcoin", amount.toFixed(0), true); } }); });
und auch das Blockly von @el_malto durchblicke ich noch nicht so ganz....
Es kommt auf deinen Link an was der liefert. Die Coinbase API liefert eine JSON Datei.
Der Inhalt sieht so aus:
{"data":{"base":"BTC","currency":"EUR","amount":"31778.28"}}
Grob erklärt:
Das JS Script definiert in Zeile 8 dieresult
Variable und schreibt das JSON in diese Variablevar result = JSON.parse(body))
. In Zeile 9 wird nun die dieamount
Variable definiert und gesagt, schreibe den Wert unterdata
amount
in die Variable. Da ist ja der aktuelle Bitcoins Kurs drin. In Zeile 10 wird nun mitsetState
der Datenpunktbitcoin
mit den Inhalt der Variableamount
(wo ja jetzt der aktuelle Bitcoin Kurs drin steht) beschrieben.Mein Blockly
hilft dir, wenn der Wert den man haben will nicht irgendwie einfacher über eine API ausgelesen werden kann. Der Quellcode sah ca. so aus:Ganz viel Code . . . </b> Detection resumed </body> . . . weitere Code
Meinen Wert (Detection resumed) den ich haben wollte steht also zwischen
</b>
und</body>
. Das Blockly sucht nun das erste auftretende</b>
und nimmt alles bis</body>
und schreibt das in dieresult
Variable. Dann gucke ich ob in derresult
VariableDetection resumed
steht und steuere dementsprechend was.
Wie gesagt, es kommt immer drauf an welche Möglichkeiten der "Anbieter" dir zum auslesen gibt.Woher bekomme ich denn die genaue URL zum Kurs Wert der in Skript angezeigt werden soll ? Wenn ich jetzt z.B. einen anderen Wert von einer anderen URL einbinden möchte ?? mit dem Internet Browser den Quelltext untersuchen, und dann die Zeile mit dem Kurs Wert heraus suchen???
Du musst gucken ob der "Anbieter" oder die Seite vielleicht eine API hat wo Dokumentiert ist wie man Werte usw. auslesen oder verarbeiten kann. Wenn es so etwas nicht gibt, musst du selber basteln wie ich es mit dem Blockly gemacht habe.
Es gibt auch den Parser Adapter -> https://github.com/ioBroker/ioBroker.parser
Der erspart dir das "selber basteln" eines Blocklys. eine hilfreiche Seite für die Syntax ist https://regex101.com/. Diese wird auch in der Adapterbeschreibung erwähnt. Man muss sich aber schon ein bisschen damit beschäftigen um die Syntax zu verstehen. Ich verstehe diese bis heute noch nicht wirklich. Habe mir alles irgendwo ergooglet und habs dann mit "try and error" hinbekommen. -
@el_malto Vielen Dank für die Erklärung
.... Ich muss mich da noch ein bissen mehr einlesen bis ich das verstehe...
Ich habe den Parser Adapter auch installiert, aber auch da kann ich noch nicht so wirklich viel mit anfangen, weil ich nicht genau weiß, was ich in die Zeilen einsetzten muss um an den Kurs Wert zu kommen ...Ich finde auch nicht so recht eine verständliche Doku für Anfänger dazu
-
-
@martink die Syntax von regex ist mir auch noch ein Rätsel. Ich konnte mir bisher alles ergooglen was ich brauche und habe mich daher noch nicht so intentiv damit beschäftigt. Aber da gibt es bestimmt im Netz irgendwo Beispiele oder so.
Ich vermute mal das du dich auf der Seite angemeldet hast und so mit dem Link https://coinmarketcap.com/watchlist/ an deine Watchlist kommst. Das wird dir so aber nicht viel nützen weil du dich ja anmelden müsstest um die Werte zu bekommen. Habe auf der Seite gesehen, dass die eine API haben. Vielleicht kannst du da mal rein gucken. Man muss sich wohl einen API Key erstellen. Über die API kann man dann vielleicht auch die Anmeldedaten übergeben und man kann dann seine Werte auslesen. Denke aber, dass das für einen Anfänger (nicht böse gemeint) zu viel des Guten ist.
Die API ist ja Dokumentiert -> https://coinmarketcap.com/api/documentation/v1/Welche Coins willst du denn auslesen?
-
@el_malto ... Ja, ich bin sonst im ioBroker , Blockly und Co. schon ganz mit mir zufrieden - aber das ist mir dann doch noch zu hoch
.... Ich möchte gerne den Aktuellen BTC = EURO Wert der Tradingbörse Coinbase... und das als json
protokoll... damit ich damit wieder im Blockly arbeiten kann -
@MartinK. said: "https://api.coinbase.com/v2/prices/spot?currency=EUR"
Mit diesem Link funktioniert es so:
-
@paul53 said in Daten aus Url abfragen und in Datenpunkt schreiben:
Mit diesem Link funktioniert es so:
@MartinK
Da würde ich auch gar nicht mit dem parser rangehen.
Das zurückgeliefert json:
{"data":{"base":"BTC","currency":"EUR","amount":"31458.0"}}
ist so minimal, dass die von @paul53 geannte Lösung die mit Sicherheit einfachste ist, zumal@el_malto said in Daten aus Url abfragen und in Datenpunkt schreiben:
die Syntax von regex ist mir auch noch ein Rätsel.
das anscheinend auch für dich gilt
-
@paul53 said in Daten aus Url abfragen und in Datenpunkt schreiben:
@MartinK. said: "https://api.coinbase.com/v2/prices/spot?currency=EUR"
Mit diesem Link funktioniert es so:
Vielen Dank.
Ich werde das gleich einmal einbauen und testen.... Aber ich ich möchte auf langer Sicht auch die Logik dahinter verstehen und wie das ganze sich zusammensetzt !
.... damit ich auch was dazu lerne !
-
@martink said: wie das ganze sich zusammensetzt !
Bei der Analyse eines JSON hilft der JSONViewer.
-
@paul53 Woher bekomme ich denn diesen Wert? Da stehe ich noch etwas auf dem Schlauch??
-
@martink einfach in Blockly unter "Variablen" eine Varibale erstellen die "result" heißt.
-
@el_malto ok, und er Punkt "data.amount" - was beschreibt der bzw. welcher Datenpunkt ist das ????
-
@martink said in Daten aus Url abfragen und in Datenpunkt schreiben:
data.amount
wenn du dir das json ansiehstgibt es eine Hierarchie
data
in der es dann den Punktamount
gibt, dessen Wert du haben willst -
@homoran ...puuh ok.... ! Und dann habe ich noch eine Frage: Im Blockly wird ja "aktualisiere Objekt ID" eingefügt,
ist das ein Datenpunkt den manuell erzeugen muss mit dem Attribut "Zahl" ? ..... Wie gesagt ich bin noch nicht so fit und solchen "tricky" Sachen .... Bis jetzt mache ich nur ein bisschen Visualisierung und hier und da ein paar Blockly Automatisierungen -
@martink said: ist das ein Datenpunkt den manuell erzeugen muss mit dem Attribut "Zahl" ?
Ja, das ist ein eigener, virtueller Datenpunkt vom Typ "Zahl" (unter "0_userdata.0").