NEWS
XML Daten (TV Programm) in ioBroker
-
Hallo zusammen,
ich habe nach http://forum.iobroker.net/viewtopic.php?f=21&t=860 versucht, das aktuelle TV Programm (http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml) in ioBroker einzulesen (xml2js installiert). Leider bisher ohne Erfolg. Der JavaScript Adapter stürzt ab. Eigentlich wollte ich erstmal ja nur zum Test den channel.title auslesen ("TV Spielfilm.de - Was läuft jetzt im Fernsehen?"), aber in result erscheint gleich die ganze XML.
Mich interessieren die Felder
- channel.item.title
- channel.item.link
- channel.item.description
item jeweils von 0 bis maximal 20
Das ganze soll für eine View "TV Programm jetzt" verwendet werden. Später nutze ich nach diesem Beispiel auch die anderen zwei RSS Feeds heute2015 und heute2200 bzw. filme (http://www.tvspielfilm.de/services/widgets/rss-feeds/rss-feeds-im-ueberblick,3538128,ApplicationArticle.html)
var parseString = require('xml2js').parseString; var request = require('request'); request('http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml', function (error, response, body) { if (!error && response.statusCode == 200) { log("Body: " + body); parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { if (err) { log("Fehler: " + err); } else { log("Result: " + result.channel.title); } }); } else { log(error); } });
Hier das log:
! ````
host-MacMini-Ethernet-fritz-box 2015-06-17 17:44:42 info Restart adapter system.adapter.javascript.0 because enabled
host-MacMini-Ethernet-fritz-box 2015-06-17 17:44:42 error instance system.adapter.javascript.0 terminated with code 6 (uncaught exception)
TypeError: 2015-06-17 17:44:42 error at process._tickCallback (node.js:419:13)
TypeError: 2015-06-17 17:44:42 error at _stream_readable.js:943:16
TypeError: 2015-06-17 17:44:42 error at IncomingMessage.emit (events.js:117:20)
TypeError: 2015-06-17 17:44:42 error at IncomingMessage. (/Users/jens/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1153:12)
TypeError: 2015-06-17 17:44:42 error at Request.emit (events.js:117:20)
TypeError: 2015-06-17 17:44:42 error at Request. (/Users/jens/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1207:14)
TypeError: 2015-06-17 17:44:42 error at Request.emit (events.js:98:17)
TypeError: 2015-06-17 17:44:42 error at Request.self.callback (/Users/jens/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:354:22)
TypeError: 2015-06-17 17:44:42 error at Request._callback (script.js.TEST_VIS_TVProgramm:8:7)
TypeError: 2015-06-17 17:44:42 error at exports.parseString (/Users/jens/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/xml2js.js:510:19)
TypeError: 2015-06-17 17:44:42 error at Parser.parseString (/Users/jens/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/xml2js.js:6:59)
TypeError: 2015-06-17 17:44:42 error at Parser.exports.Parser.Parser.parseString (/Users/jens/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/xml2js.js:482:16)
TypeError: 2015-06-17 17:44:42 error at Parser.emit (events.js:74:15)
TypeError: 2015-06-17 17:44:42 error at TypeError (:null:null)
TypeError: 2015-06-17 17:44:42 error Uncaught, unspecified "error" event.
uncaught 2015-06-17 17:44:42 error exception: Uncaught, unspecified "error" event.
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107073158401,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9A5GJ71G7h8EmJyN_GHYX_QrQ9uWDoVlyL9zt9ediQqVQ==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/daheim-und-unterwegs,107074314140.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074314140
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info ]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/mord-ist-ihr-hobby,107074166589.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074166589
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Heute: "Hamburgs Wildnis", Hamburg]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/mein-lokal-dein-lokal-wo-schmeckts-am-besten,107074218678.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074218678
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Tag 3
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107076155765,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9D7Xm+r30BoKFjF5Y9IGfnBhvt8ioIXtR89de+fWKR9Qw==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/mein-himmlisches-hotel,107074337218.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074337218
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Roza ist seit einem Jahr Single, doch das soll nun vorbei sein. Sie ist spontan und offen für Abenteuer. Bei 'Next, Please!' will Roza mit ihren V
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/next-please,107074227658.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074227658
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Profi checkt Profi]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/taff,107075351706.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107075351706
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Rund ums Essen - Frühstück]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/moderne-wunder,107074249278.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074249278
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Charlies Engel - das sind die drei talentierten und attraktiven Polizistinnen Sabrina Duncan, Jill Munroe und Kelly Garrett. Gelangweilt vom eint
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/drei-engel-fuer-charlie,107074326439.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074326439
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Auf d
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107035051915,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9DKIzPLbdG9q6E9fsb0YAllIUpWcsle93LY_iPOO2kNng==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/star-trek-raumschiff-voyager,107074205121.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074205121
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info "hall
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107066715997,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9BlrqqhhwB09oYIQZFpn37S7csV3pnqxYJi5sJkSqwaCg==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/hallo-deutschland,107075784509.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107075784509
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Russi
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107019336713,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9CUaSoYYxZ2kvK5BTTy6NkZnGsH7DkZeQSH3H59934FPQ==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/siberian-cut-holzfaeller-am-limit,107074292381.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074292381
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107066557302,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9C2YCZvDym4QvI+fMawxr6KH8ay1DugE1SukYgpIzf85w==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/brisant,107075783753.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107075783753
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info ]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/one-piece,107074306163.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074306163
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Der Meeresbiologe Mark Meekan kommt seit zehn Jahren an die...]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Das U
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107075802117,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9Ak33HgMali9dijACK2jmYrNbbral5rYmMsjtEHmL8wkg==.jpg
javascript-0 2015-06-17 17:44:42 info Der Meeresbiologe Mark Meekan kommt seit zehn Jahren an die...]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/australiens-nationalparks,107074203183.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074203183
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info ]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/die-wilden-siebziger,107074150420.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074150420
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107017013616,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9CXMBtLUtKXWSqAet8P0WI8ZW4LgYq7T73bbrcZyVzfiA==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/ghost-whisperer-stimmen-aus-dem-jenseits,107075346478.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107075346478
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Rechtsmedizinerin mit Herz]]>
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/schicksale-und-ploetzlich-ist-alles-anders,107075784541.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107075784541
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Zum Ärgernis vo
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 7709333,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9Bw_OV3sGEWr2FyvvAwRNu_EHAvGorghhErNZ1fq7+nRA==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/unter-uns,107074228864.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074228864
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Jack, ein alter Freund von Colonel Potter, wird bei einer Routineuntersuchung positiv auf Diabetes getestet. Er wird daraufhin für fluguntauglich
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/mash,107074246775.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107074246775
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info 107075807744,mdbradfFRaZlKlOj+DysWupja5ukGulK4tyIsYv6W9CUaSoYYxZ2kvK5BTTy6NkZnGsH7DkZeQSH3H59934FPQ==.jpg
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendung/wildes-venedig,107073879944.html
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info Broadcast 107073879944
javascript-0 2015-06-17 17:44:42 info Wed, 17 Jun 2015 17:44:11 GMT
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/tv-sender/
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info http://a2.tvspielfilm.de/images/rss/jetztimtv.png
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info de-de
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de
javascript-0 2015-06-17 17:44:42 info TV Programm
javascript-0 2015-06-17 17:44:42 info Das läuft jetzt im TV: Das aktuelle Programm von heute im Fernsehen übersichtlich dargestellt auf TV SPIELFILM
javascript-0 2015-06-17 17:44:42 info http://www.tvspielfilm.de/tv-programm/sendungen/jetzt.php
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info
javascript-0 2015-06-17 17:44:42 info script.js.TEST_VIS_TVProgramm: Body:
javascript-0 2015-06-17 17:44:42 info script.js.TEST_VIS_TVProgramm: registered 0 subscriptions and 0 schedules
javascript-0 2015-06-17 17:44:41 info Start javascript script.js.TEST_VIS_TVProgrammWarum stürzt der Adapter ab? Gruß Pix ****EDIT - Ich habe das Skript wieder mal angepasst und poste es jetzt wegen der Übersicht im ersten Thread**** <u>18.1.2016</u> aktuelles Skript TV Tipps mit Sender-Blacklist als Array (lässt sich, falls mal Adapter, besser von Einstellungen aus pflegen) aktuelles Skript TV Programm jetzt CSS für VIS und Widget für Tipps Widget für Programm jetzt >! Aktueller Code TV Spielfilm Tipps``` `/* VIS TV Programm Tipps >! bringt das TV Programm von RSS Feed von TV Spielfilm in iobroker http://www.tvspielfilm.de/services/widgets/rss-feeds/rss-feeds-im-ueberblick,3538128,ApplicationArticle.html >! erstellt: 24.06.2015 von Pix mit Hilfe von bluefox 26.06.2015 wieder mit Bluefox Hilfe erneuert (JSON Tabelle ausgeben) 23.07.2015 Aufruf alle 10min, nicht minütlich 01.08.2015 Umzug auf javascript.1 Adapter 03.09.2015 Optin 18.11.2015 Überprüfung, ob Sender empfangbar (function check_sender) 20.11.2015 Senderliste erweitert 11.12.2015 Senderliste erweitert 12.12.2015 Senderliste erweitert 16.12.2015 Senderliste erweitert 01.01.2016 Bei Optin Einlesen starten 18.01.2016 ID überarbeitet Instanz in Variable Blacklist Code optimiert auf Array */ >! var instanz = 'javascript.1'; var link = 'http://www.tvspielfilm.de/tv-programm/rss/filme.xml'; >! createState('TV_Programm.tvspielfilm.Tipps.json', '[]'); createState('TV_Programm.tvspielfilm.Tipps.xml'); >! var idOptin = instanz + '.TV_Programm.Optin', idXML = instanz + '.TV_Programm.tvspielfilm.Tipps.xml', idJSON = instanz + '.TV_Programm.tvspielfilm.Tipps.json'; >! // Überprüft, ob Sender empfangbar (Rückgabe true;false) >> Blacklist function check_sender (ueberschrift) { // wird so übergeben "16:50 | Sky Cinema | Kill the Boss 2" var ueberschrift_teile = ueberschrift.split(' | '); var sender = ueberschrift_teile[1]; var empfangbar; var blacklist = []; blacklist = ['Silverline', 'Sky Action', 'Sky Cinema', 'Sky Comedy', 'MGM HD', 'Sky Nostalgie', 'KinoweltTV', 'Sky Emotion', 'Sky 007 HD', 'Disney Channel', 'Sony E. Television', 'TNT Film', 'Sky Hits HD', 'Disney Cinemagic', 'AXN', 'Syfy', 'Sky Atlantic HD' ]; var suchergebnis = blacklist.indexOf(sender,0); // Ergebnis ist die Position im Array oder "-1", wenn nicht gefunden empfangbar = (suchergebnis == -1) ? true : false; // Sender nicht in der Blacklist, also empfangbar return(empfangbar); } >! function TvProgrammEinlesen () { // alle 5 Minuten var optin = getState(idOptin).val; var parseString = require('xml2js').parseString; var request = require('request'); >! if (optin) request(link, function (error, response, body) { if (!error && response.statusCode == 200) { parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState(idXML, data); // ganze XML in Objekt für Table Widget var table = []; if (err) { log("Fehler: " + err); } else { var sender_empfangbar = false; if (result.rss.channel.item.length !== null) { // gelegentlicher Fehler bei nächtlicher Abfrage durch length (undefined) soll hier abgefangen werden // Array durchzaehlen von 0 bis Zahl der items for(var i = 0; i < result.rss.channel.item.length; i++) { sender_empfangbar = check_sender(result.rss.channel.item[i].title); if (sender_empfangbar) { var entry = { image: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : '', text: ' >! | [' + result.rss.channel.item[i].title + '](' + result.rss.channel.item[i].link + ') | | ' + result.rss.channel.item[i].description +' | >! ', _Bild: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : 'no image' }; table.push(entry); } // Ende Abfrage, ob Sender empfangbar } } else log('LENGTH in TV Programm Jetzt nicht definiert'); // ende if ungleich } setState(idJSON, JSON.stringify(table)); // ganze XML in Objekt für Table Widget }); } else { log(error); } }); // Ende request // log('XML-Daten aus TV Spielfilm eingelesen'); } >! schedule("7 6,9,12,15,18 * * *", TvProgrammEinlesen); // Um 6-18Uhr alle 3 Stunden jeweils um 7min nach voll (geht hier nur um die TV-Tipps für den Tag) TvProgrammEinlesen(); >! // Opt In setzen - bei true Einlesen starten on(idOptin, function (obj) { if (obj.newState.val === true) TvProgrammEinlesen; });` Aktueller Code TV Spielfilm Programm jetzt `~~[code]~~/* VIS TV Programm jetzt >! bringt das TV Programm von RSS Feed von TV Spielfilm in iobroker http://www.tvspielfilm.de/services/widgets/rss-feeds/rss-feeds-im-ueberblick,3538128,ApplicationArticle.html >! erstellt: 18.06.2015 von Pix mit Hilfe von bluefox 23.06.2015 Schedule zugefügt 26.06.2015 neuer Aufbau (durch Bluefox), Nutzung JSON Tabelle 23.07.2015 Start alle 10min, nicht jede Minute (hatte zu Fehler beim Aufruf geführt) 01.08.2015 Umzug auf javascript.1 Adapter 03.09.2015 Optin 01.01.2016 Bei Optin Einlesen starten 18.01.2016 ID überarbeitet Instanz in Variable */ var instanz = 'javascript.1'; >! createState('TV_Programm.tvspielfilm.jetzt.xml'); createState('TV_Programm.tvspielfilm.jetzt.json', '[]'); createState('TV_Programm.Optin', true, {name: 'Optin TV Webseite Daten abrufen', type: 'boolean', desc: 'Sollen TV-Webdaten abgerufen werden?'}); >! var idOptin = instanz + '.TV_Programm.Optin', optin_beschreibung = 'TV Programm Daten', idXML = instanz + '.TV_Programm.tvspielfilm.jetzt.xml', idJSON = instanz + '.TV_Programm.tvspielfilm.jetzt.json'; >! var link = 'http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml'; >! function TvProgrammEinlesen () { // alle 5 Minuten var optin = getState(idOptin).val; var parseString = require('xml2js').parseString; var request = require('request'); >! if (optin) request(link, function (error, response, body) { if (!error && response.statusCode == 200) { parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState(idXML, data); // ganze XML in Objekt für Table Widget var table = []; if (err) { log("Fehler: " + err); } else { if (result.rss.channel.item.length !== null) { // gelegentlicher Fehler bei nächtlicher Abfrage durch length (undefined) soll hier abgefangen werden // Array durchzaehlen von 0 bis Zahl der items for(var i = 0; i < result.rss.channel.item.length; i++) { var entry = { image: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : '', text: ' >! | [' + result.rss.channel.item[i].title + '](' + result.rss.channel.item[i].link + ') | | ' + result.rss.channel.item[i].description +' | >! ', _Bild: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : 'no image' }; table.push(entry); } } else log('LENGTH in TV Programm Jetzt nicht definiert'); // ende if ungleich } setState(idJSON, JSON.stringify(table)); // ganze XML in Objekt für Table Widget }); } else { log(error); } }); // Ende request // log('XML-Daten aus TV Spielfilm eingelesen'); } >! // Opt In setzen - Logging on(idOptin, function (obj) { log('Opt in Variable <' + optin_beschreibung + '> auf <' + obj.newState.val + '> gesetzt ', 'info'); TvProgrammEinlesen; }); >! schedule("*/10 * * * *", TvProgrammEinlesen); //alle 10min TvProgrammEinlesen();` >! CSS für VIS Projekt `~~[code]~~/* -------- TV Programm ----- */ >! .tclass-th { /* Headerzeilen */ background-color: darkgrey; background-color: rgba(100,100,100,0.8); color: white; font-weight: bold; font-family: Arial; } >! .tclass-th1 { /* linker Header */ width: 20px; text-align: center; color: transparent; /* Text ausblenden */ /* display: none; */ /* ganze Spalte ausblenden */ } >! .tclass-th .tclass-th1 { display: none; /* Spaltenüberschrift überm Bild ausblenden*/ } >! .tclass-tr { color: red; } >! .tclass-tr:nth-child(odd) { background-color: darkgreen; background-color: rgba(50,120,80,0.6); } >! .tclass-tr:nth-child(even) { color: yellow; background-color: darkred; background-color: rgba(150,150,150,0.2); } >! .tv_tipps, .tv_jetzt { font-family: Arial; font-size: 75%; } >! .tv_tipps tr, .tv_jetzt tr { background-color: transparent; color: white; } >! .tv_tipps tr td a, .tv_jetzt tr td a { background-color: transparent; color: white; text-decoration: none; } >! .tv_jetzt tr td a { font-size: 130%; } [/code]` >! Widget für Tipps `~~[code]~~[{"tpl":"tplTableBody","data":{"visibility-cond":"==","visibility-val":1,"static_value":"","table_oid":"javascript.1.TV_Programm.tvspielfilm.Tipps.json","colCount":"2","colName1":"Vorschau","colWidth1":"30px","colName2":"Tagestipps","colAttr1":"","colWidth2":"60px","hide_header":false,"show_scroll":false,"new_on_top":true,"name":"JSON Tabelle TV Programm TIPPS"},"style":{"left":"6px","top":205,"width":"357px","height":"auto","z-index":"25","color":"rgba(250,250,250,1)","text-align":"","font-family":"","background-color":"","border-style":""},"widgetSet":"basic"}][/code]` >! Widget für Programm Jetzt `~~[code]~~[{"tpl":"tplTableBody","data":{"visibility-cond":"==","visibility-val":1,"static_value":"","table_oid":"javascript.1.TV_Programm.tvspielfilm.jetzt.json","colCount":"2","colName1":"Vorschau","colWidth1":"140px","colName2":"Jetzt im TV","colAttr1":"","colWidth2":"100%","hide_header":false,"show_scroll":false,"new_on_top":true,"name":"JSON Tabelle TV Programm JETZT"},"style":{"left":365,"top":205,"width":"653px","height":"1977px","z-index":"25","color":"rgba(250,250,250,1)","text-align":"","font-family":"","background-color":"","border-style":""},"widgetSet":"basic"}][/code]` >! Edit 08.05.2016 Adapter übernimmt die Funktion dieses Skriptes -> [http://forum.iobroker.net/viewtopic.php?f=20&t=2821#p25427](http://forum.iobroker.net/viewtopic.php?f=20&t=2821#p25427)[/i][/i][/i][/i][/i][/i][/i][/code][/i][/i][/i][/i][/i][/i][/i][/i] ```
-
var parseString = require('xml2js').parseString; var request = require('request'); //var log = console.log; request('http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml', function (error, response, body) { if (!error && response.statusCode == 200) { parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); if (err) { log("Fehler: " + err); } else { log("Result: " + result.rss.channel.title); } }); } else { log(error); } });
Fehler war in "result.rss.channel.title"
Man kann einfach die Struktur mit dem Befehl:
console.log(JSON.stringify(result, null, 2));
anschauen.
-
Hallo,
ich habe das Skript noch etwas weitergebaut und stehe jetzt vor einem neuen Problem:
Das Programm wird als JSON ausgelesen, jede Sendung ist in item-Tags eingefasst. Ich zaehle alle items und habe die Zahl der Sendungen. Klar.
Jetzt möchte ich für jede Sendung vier Objekte anlegen (description, image, link und title). Beim Durchiterieren nutze ich createState und ich glaube, das ist ganz schlecht !```
createState('TV_Programm.tvspielfilm.jetzt.' + [i] + '.title');
Da kommt dieser Fehler im log:
~~[code]~~2015-06-23 19:36:00.422 - error: uncaught exception: Uncaught, unspecified "error" event. 2015-06-23 19:36:00.428 - error: TypeError: Uncaught, unspecified "error" event. at TypeError (<anonymous>:null:null) at Parser.emit (events.js:74:15) at Parser.exports.Parser.Parser.parseString (/Users/pix/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/xml2js.js:482:16) at Parser.parseString (/Users/pix/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/xml2js.js:6:59) at exports.parseString (/Users/pix/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/xml2js/lib/xml2js.js:510:19) at Request._callback (script.js.ATEST_VIS_TVProgramm:23:13) at Request.self.callback (/Users/pix/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:354:22) at Request.emit (events.js:98:17) at Request. <anonymous>(/Users/pix/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1207:14) at Request.emit (events.js:117:20) at IncomingMessage. <anonymous>(/Users/pix/Desktop/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1153:12) at IncomingMessage.emit (events.js:117:20) at _stream_readable.js:943:16 at process._tickCallback (node.js:419:13) [/code]</anonymous></anonymous></anonymous>
Das Skript:
`[code]/* VIS TV Programmbringt das TV Programm von RSS Feed von TV Spielfilm in iobroker
erstellt: 18.06.2015 von Pix mit Hilfe von bluefox
23.06.2015 Schedule zugefügt
*/createState('TV_Programm.tvspielfilm.jetzt.xml');
var link = 'http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml';
schedule("*/1 * * * *", function () { // alle 5 Minuten
var parseString = require('xml2js').parseString; var request = require('request'); request(link, function (error, response, body) { if (!error && response.statusCode == 200) { parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState("javascript.0.TV_Programm.tvspielfilm.jetzt.xml"/*TV_Programm.tvspielfilm.jetzt.xml*/, data); // ganze XML in Objekt für Table Widget if (err) { log("Fehler: " + err); } else { // Array durchzaehlen von 0 bis Zahl der items for(var i=0;i<result.rss.channel.item.length;i++) {/createstate('tv_programm.tvspielfilm.jetzt.'/+/[i]/'.title');/'.link');/'.description');/'.image');/log('-------------------------------------------')/log('tv-sendung/'/i);/log("result:/"/result.rss.channel.item[i].title);/result.rss.channel.item[i].link);/result.rss.channel.item[i].description);/result.rss.channel.item[i].enclosure.url);/result.rss.channel.item[i].content:encoded);/setstate("javascript.0.tv_programm.tvspielfilm.jetzt."/".title",/".link",/".description",/".image",/"<img/width="100%" src="" + result.rss.channel.item[i].enclosure.url + "">"); } } }); } else { log(error); } }); // Ende request log('XML-Daten aus TV Spielfilm eingelesen');
});</result.rss.channel.item.length;i++)>`
Und die Objekte:
Die Zahl der Sendungen, die ausgegeben werden schwankt. Mal 20, mal mehr und mal weniger. Deshalb das Anlegen/createState in der for-Schleife. Wenn es weniger Sendungen sind, werden die alten nicht gelöscht. Das ist auch nicht gut, da dann veraltete Daten angezeigt werden (aus einem Durchgang, als mehr Sendungen als dieses Mal im Array standen). Die müssten vor jeder neuen Beschreibung erstmal gelöscht werden. Aber wie kann ich zählen, wieviele Objekte es aktuell sind?
Wie kann ich das lösen? Alles lokal in ein Array speichern und dann das Array in die Objekte schreiben bringt doch auch keinen Unterschied, oder?
Gruß
Pix
PS: VIS-View-Entwurf
!
[spoiler][/spoiler][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/code][/i] -
Fehler war in dem, dass manche Einträge kein result.rss.channel.item__.enclosure hatten und dann ging result.rss.channel.item__.enclosure.url nicht
Warum das:____ __```
createState('TV_Programm.tvspielfilm.jetzt.' + [i] + '.title');
Sollte eigentlich sein:
~~[code]~~createState('TV_Programm.tvspielfilm.jetzt.' + i + '.title');[/code]
Das Bild sieht schon schick aus, aber ich denke dass die Denkrichtung ist falsch. Man muss JSON Tabelle erzeugen und die mit Hilfe von basic- table zeigen.
Irgendwie so:
`[code]/* VIS TV Programmbringt das TV Programm von RSS Feed von TV Spielfilm in iobroker
erstellt: 18.06.2015 von Pix mit Hilfe von bluefox
23.06.2015 Schedule zugefügt
*/createState('TV_Programm.tvspielfilm.jetzt.xml');
createState('TV_Programm.tvspielfilm.jetzt.json', '[]');var link = 'http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml';
function buldTvProgramm () { // alle 5 Minuten
var parseString = require('xml2js').parseString; var request = require('request'); request(link, function (error, response, body) { if (!error && response.statusCode == 200) { parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState("javascript.0.TV_Programm.tvspielfilm.jetzt.xml"/*TV_Programm.tvspielfilm.jetzt.xml*/, data); // ganze XML in Objekt für Table Widget var table = []; if (err) { log("Fehler: " + err); } else { // Array durchzaehlen von 0 bis Zahl der items for(var i = 0; i < result.rss.channel.item.length; i++) { var entry = { image: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : '', text: '
| [' + result.rss.channel.item[i].title +
'](' +
result.rss.channel.item[i].link + ') |
| ' +
result.rss.channel.item[i].description +' |',
_Bild: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : 'no image'
};
table.push(entry);
}
}
setState("javascript.0.TV_Programm.tvspielfilm.jetzt.json", JSON.stringify(table)); // ganze XML in Objekt für Table Widget}); } else { log(error); } }); // Ende request log('XML-Daten aus TV Spielfilm eingelesen');
}
schedule("*/1 * * * *", buldTvProgramm);
buldTvProgramm();`Widgets:
!
[spoiler]~~[code]~~{ "settings": { "style": { "background_class": "" }, "theme": "redmond", "sizex": "1024", "sizey": "748", "hideDescription": false, "gridSize": "" }, "widgets": { "e00001": { "tpl": "tplHqCheckbox", "data": { "visibility-cond": "==", "visibility-val": 1, "oid": "dev2", "checkboxSize": "small", "checkboxColor": "orange" }, "style": { "left": "1160px", "top": "148px" }, "widgetSet": "hqWidgets" }, "e00002": { "tpl": "tplTableBody", "data": { "visibility-cond": "==", "visibility-val": 1, "static_value": "", "table_oid": "javascript.0.TV_Programm.tvspielfilm.jetzt.json", "colCount": "2", "colWidth1": "100px", "colWidth2": "100%", "hide_header": true, "detailed_wid": "w00001" }, "style": { "left": "8px", "top": "5px", "width": "727px", "height": "432px" }, "widgetSet": "basic" }, "e00003": { "tpl": "tplHtml", "data": { "visibility-cond": "==", "visibility-val": 1, "refreshInterval": "0", "html": "Im Tabelle anklicken" }, "style": { "left": "742px", "top": "5px", "width": "367px", "height": "131px", "background-color": "#d8c7ef" }, "widgetSet": "basic" } }, "rerender": false, "filterList": [] }[/code]
[/spoiler]
Natürlich solle es noch "aufgehübscht" sein.
48_img_007.png [/i][/i][/i][/i][/i][/i][/i][/code][/i] -
Hallo,
klappt gut. Danke.
@Bluefox:Natürlich solle es noch "aufgehübscht" sein. `
wo kann ich das machen. Eintragungen im Reiter VIS/Eigenschaften/CSS bleiben nicht erhalten (sowohl Projekt als auch global).Gruß
Pix
-
Bitte updaten auf js-controller 0.7.1 und vis 0.6.1
-
Hallo,
ich habe das Skript heute nochmal etwas angepasst. Jetzt werden keine Sky-Sender mehr in den Tagestipps angezeigt (ich habe kein Sky). Die Liste der Sender, die nicht angezeigt werden sollen, kann man einfach in die Switch-Abfrage in der Funktion check_sender einbauen.
! ```
`/* VIS TV Programm jetzt
! bringt das TV Programm von RSS Feed von TV Spielfilm in iobroker
http://www.tvspielfilm.de/services/widgets/rss-feeds/rss-feeds-im-ueberblick,3538128,ApplicationArticle.html
! erstellt: 24.06.2015 von Pix mit Hilfe von bluefox
26.06.2015 wieder mit Bluefox Hilfe erneuert (JSON Tabelle ausgeben)
23.07.2015 Aufruf alle 10min, nicht minütlich
01.08.2015 Umzug auf javascript.1 Adapter
03.09.2015 Optin
18.11.2015 Überprüfung, ob Sender empfangbar (function check_sender) neu
*/
! createState('TV_Programm.tvspielfilm.Tipps.json', '[]');
createState('TV_Programm.tvspielfilm.Tipps.xml');
! var idOptin = 'TV_Programm.Optin';
var link = 'http://www.tvspielfilm.de/tv-programm/rss/filme.xml';
! // Überprüft, ob Sender empfangbar (Rückgabe true;false)
function check_sender (ueberschrift) { // wird so übergeben "16:50 | Sky Cinema | Kill the Boss 2"
var ueberschrift_teile = ueberschrift.split(' | ');
var sender = ueberschrift_teile[1];
var empfangbar;
switch (sender) {
case 'Sky Cinema':
empfangbar = false;
break;
case 'Sky Comedy':
empfangbar = false;
break;
case 'MGM HD':
empfangbar = false;
break;
case 'Sky Nostalgie':
empfangbar = false;
break;
case 'KinoweltTV':
empfangbar = false;
break;
case 'Sky Emotion':
empfangbar = false;
break;
default:
empfangbar = true;
break;
}
return(empfangbar);
}
! function TvProgrammEinlesen () { // alle 5 Minuten
var optin = getState(idOptin).val;
var parseString = require('xml2js').parseString;
var request = require('request');
! if (optin) request(link, function (error, response, body) {
if (!error && response.statusCode == 200) {parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState("javascript.1.TV_Programm.tvspielfilm.Tipps.xml"/*TV_Programm.tvspielfilm.Tipps.xml*/, data); // ganze XML in Objekt für Table Widget var table = []; if (err) { log("Fehler: " + err); } else { var sender_empfangbar = false; // Array durchzaehlen von 0 bis Zahl der items for(var i = 0; i < result.rss.channel.item.length; i++) { sender_empfangbar = check_sender(result.rss.channel.item[i].title); if (sender_empfangbar) { var entry = { image: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : '', text: '
! | [' + result.rss.channel.item[i].title +
'](' +
result.rss.channel.item[i].link + ') |
| ' +
result.rss.channel.item[i].description +' |
! ',
_Bild: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : 'no image'
};
table.push(entry);
} // Ende Abfrage, ob Sender empfangbar
}
}
setState("javascript.1.TV_Programm.tvspielfilm.Tipps.json", JSON.stringify(table)); // ganze XML in Objekt für Table Widget}); } else { log(error); } }); // Ende request // log('XML-Daten aus TV Spielfilm eingelesen');
}
! schedule("/10 * * * ", TvProgrammEinlesen);
TvProgrammEinlesen();! CSS für Table-Widget: ! >! ~~[spoiler]~~
[code]/ ---------------------- Sample for table widget TV ------------------------- /
! .tclass-th { / Headerzeilen /
background-color: darkgrey;
background-color: rgba(100,100,100,0.8);
color: white;
font-weight: bold;
font-family: Arial;
}
! .tclass-th1 { / linker Header /
width: 20px;
text-align: center;
color: transparent; / Text ausblenden /
/ display: none; / / ganze Spalte ausblenden /
}
! .tclass-th .tclass-th1 {
display: none; / Spaltenüberschrift überm Bild ausblenden/
}
! .tclass-tr {
color: red;
}
! .tclass-tr:nth-child(odd) {
background-color: darkgreen;
background-color: rgba(50,120,80,0.6);
}
! .tclass-tr:nth-child(even) {
color: yellow;
background-color: darkred;
background-color: rgba(150,150,150,0.2);
}
! .tv_tipps,
.tv_jetzt {
font-family: Arial;
font-size: 75%;
}
! .tv_tipps tr,
.tv_jetzt tr {
background-color: transparent;
color: white;
}
! .tv_tipps tr td a,
.tv_jetzt tr td a {
background-color: transparent;
color: white;
text-decoration: none;
}
! .tv_jetzt tr td a {
font-size: 130%;
}
[/code]`[/spoiler]
Sieht so aus:
! Gruß
! Pix[/i][/i][/i][/i][/i][/i][/i][/i] -
Hallo Pix,
wie hattest du das jetzt gemacht?
Den ersten Teil als Script angelegt (Name: VIS TV Programm)
`/* VIS TV Programm jetzt bringt das TV Programm von RSS Feed von TV Spielfilm in iobroker http://www.tvspielfilm.de/services/widgets/rss-feeds/rss-feeds-im-ueberblick,3538128,ApplicationArticle.html erstellt: 24.06.2015 von Pix mit Hilfe von bluefox 26.06.2015 wieder mit Bluefox Hilfe erneuert (JSON Tabelle ausgeben) 23.07.2015 Aufruf alle 10min, nicht minütlich 01.08.2015 Umzug auf javascript.1 Adapter 03.09.2015 Optin 18.11.2015 Überprüfung, ob Sender empfangbar (function check_sender) neu */ createState('TV_Programm.tvspielfilm.Tipps.json', '[]'); createState('TV_Programm.tvspielfilm.Tipps.xml'); var idOptin = 'TV_Programm.Optin'; var link = 'http://www.tvspielfilm.de/tv-programm/rss/filme.xml'; // Überprüft, ob Sender empfangbar (Rückgabe true;false) function check_sender (ueberschrift) { // wird so übergeben "16:50 | Sky Cinema | Kill the Boss 2" var ueberschrift_teile = ueberschrift.split(' | '); var sender = ueberschrift_teile[1]; var empfangbar; switch (sender) { case 'Sky Cinema': empfangbar = false; break; case 'Sky Comedy': empfangbar = false; break; case 'MGM HD': empfangbar = false; break; case 'Sky Nostalgie': empfangbar = false; break; case 'KinoweltTV': empfangbar = false; break; case 'Sky Emotion': empfangbar = false; break; default: empfangbar = true; break; } return(empfangbar); } function TvProgrammEinlesen () { // alle 5 Minuten var optin = getState(idOptin).val; var parseString = require('xml2js').parseString; var request = require('request'); if (optin) request(link, function (error, response, body) { if (!error && response.statusCode == 200) { parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState("javascript.1.TV_Programm.tvspielfilm.Tipps.xml"/*TV_Programm.tvspielfilm.Tipps.xml*/, data); // ganze XML in Objekt für Table Widget var table = []; if (err) { log("Fehler: " + err); } else { var sender_empfangbar = false; // Array durchzaehlen von 0 bis Zahl der items for(var i = 0; i < result.rss.channel.item.length; i++) { sender_empfangbar = check_sender(result.rss.channel.item[i].title); if (sender_empfangbar) { var entry = { image: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : '', text: ' | [' + result.rss.channel.item[i].title + '](' + result.rss.channel.item[i].link + ') | | ' + result.rss.channel.item[i].description +' | ', _Bild: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : 'no image' }; table.push(entry); } // Ende Abfrage, ob Sender empfangbar } } setState("javascript.1.TV_Programm.tvspielfilm.Tipps.json", JSON.stringify(table)); // ganze XML in Objekt für Table Widget }); } else { log(error); } }); // Ende request // log('XML-Daten aus TV Spielfilm eingelesen'); } schedule("*/10 * * * *", TvProgrammEinlesen); TvProgrammEinlesen();` dann eine Basic -Tabelle (json , table Table) und dann? An welcher Stelle fügst du des CSS Code ein? [2417_fehler.jpg](/assets/uploads/files/2417_fehler.jpg) [/i][/i][/i][/i][/i][/i][/i][/i]
-
Im Reiter rechts auf css Projekt einfügen.
Gesendet von meinem iPhone mit Tapatalk
-
Hi oh hatte das übersehen.
Alles andere ist so weit richtig?
Was nimmst du denn bei "Table Objekt ID"?
-
Hallo und danke schonmal für das Skript.
Wenn ich es allerdings ausführe erscheint im Log folgendes
javascript.0 2015-11-18 18:46:23 error javascript.0 script.js.VIS_TV_Programm: TypeError: Cannot read property 'val' of null at TvProgrammEinlesen (script.js.VIS_TV_Programm:56:34) at script.js.VIS_TV_Programm:104:1 javascript.0 2015-11-18 18:46:23 warn javascript.0 State "TV_Programm.Optin" not found javascript.0 2015-11-18 18:46:23 info javascript.0 Start javascript script.js.VIS_TV_Programm
Was kann der Grund dafür sein?
Besten Dank schonmal
Viele Grüße
David
-
Was nimmst du denn bei "Table Objekt ID"? `
javascript.1.TV_Programm.tvspielfilm.Tipps.jsonPix
-
Hallo David,
@shortyle:Hallo und danke schonmal für das Skript.
Wenn ich es allerdings ausführe erscheint im Log folgendes
javascript.0 2015-11-18 18:46:23 error javascript.0 script.js.VIS_TV_Programm: TypeError: Cannot read property 'val' of null at TvProgrammEinlesen (script.js.VIS_TV_Programm:56:34) at script.js.VIS_TV_Programm:104:1 javascript.0 2015-11-18 18:46:23 warn javascript.0 State "TV_Programm.Optin" not found javascript.0 2015-11-18 18:46:23 info javascript.0 Start javascript script.js.VIS_TV_Programm
Was kann der Grund dafür sein?
Besten Dank schonmal
Viele Grüße
David `
die Variable TV-Programm.Optin ist noch eine Zusatzfunktion, die ich eingebaut habe, um das Abrufen der Daten aus dem Netz zum Beispiel bei Urlaub oder Nachtruhe auszuschalten (Datenvolumen sparen, ggf. Fehler, wenn Quellwebseite aus, etc.).
Füge oben im Skript einfach diese Zeile ein:
createState('TV_Programm.Optin', true, {name: 'Optin TV Webseite Daten abrufen', type: 'boolean', desc: 'Sollen TV-Webdaten abgerufen werden?'});
Achtung: Das Schalten dieser Optin-Variable auf true bedeutet nicht, dass die Daten sofort neu eingelesen werden!
Alternativ nutze diesen Code in einem zweiten Skript:
! ```
`/* VIS TV Programm
! bringt das TV Programm von RSS Feed von TV Spielfilm in iobroker
http://www.tvspielfilm.de/services/widgets/rss-feeds/rss-feeds-im-ueberblick,3538128,ApplicationArticle.html
! erstellt: 18.06.2015 von Pix mit Hilfe von bluefox
23.06.2015 Schedule zugefügt
26.06.2015 neuer Aufbau (durch Bluefox), Nutzung JSON Tabelle
23.07.2015 Start alle 10min, nicht jede Minute (hatte zu Fehler beim Aufruf geführt)
01.08.2015 Umzug auf javascript.1 Adapter
03.09.2015 Optin
*/
! createState('TV_Programm.tvspielfilm.jetzt.xml');
createState('TV_Programm.tvspielfilm.jetzt.json', '[]');
createState('TV_Programm.Optin', true, {name: 'Optin TV Webseite Daten abrufen', type: 'boolean', desc: 'Sollen TV-Webdaten abgerufen werden?'});
! var idOptin = 'TV_Programm.Optin',
optin_beschreibung = 'TV Programm Daten';
! var link = 'http://www.tvspielfilm.de/tv-programm/rss/jetzt.xml';
! function TvProgrammEinlesen () { // alle 5 Minuten
var optin = getState(idOptin).val;
var parseString = require('xml2js').parseString;
var request = require('request');
! if (optin) request(link, function (error, response, body) {
if (!error && response.statusCode == 200) {parseString(body, { explicitArray: false, mergeAttrs: true }, function (err, result) { //console.log(JSON.stringify(result, null, 2)); var data = JSON.stringify(result, null, 2); setState("javascript.1.TV_Programm.tvspielfilm.jetzt.xml"/*TV_Programm.tvspielfilm.jetzt.xml*/, data); // ganze XML in Objekt für Table Widget var table = []; if (err) { log("Fehler: " + err); } else { // Array durchzaehlen von 0 bis Zahl der items for(var i = 0; i < result.rss.channel.item.length; i++) { var entry = { image: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : '', text: '
! | [' + result.rss.channel.item[i].title +
'](' +
result.rss.channel.item[i].link + ') |
| ' +
result.rss.channel.item[i].description +' |
! ',
_Bild: result.rss.channel.item[i].enclosure ? '![](' + result.rss.channel.item[i].enclosure.url + ')' : 'no image'
};
table.push(entry);
}
}
setState("javascript.1.TV_Programm.tvspielfilm.jetzt.json", JSON.stringify(table)); // ganze XML in Objekt für Table Widget}); } else { log(error); } }); // Ende request // log('XML-Daten aus TV Spielfilm eingelesen');
}
! // Opt In setzen - Logging
on( {
id: idOptin,
change: 'ne'
}, function (obj) {
if (obj.newState.val === false || obj.newState.val =='false') {
log('Opt in Variable <' + optin_beschreibung + ' Push> auf <aus '/+/obj.newstate.val=""> gesetzt ', 'info');
} else if (obj.newState.val === true || obj.newState.val =='true') {
log('Opt in Variable <' + optin_beschreibung + ' Push> auf <ein '/+/obj.newstate.val=""> gesetzt ', 'info');
}
});
! schedule("*/10 * * * *", TvProgrammEinlesen);
TvProgrammEinlesen();</ein></aus>`
Das ist praktisch das gleiche nochmal für das aktuelle TV Programm (was läuft jetzt?). Da werden allerdings keine Sky-Sender ausgeklammert. Die CSS-Steuerung ist identisch. Also einfach ein neues Table-Widget und OID mit "javascript.1.TV_Programm.tvspielfilm.jetzt.json" füllen. Die Optin - Variable wird in diesem Skript erstellt.
! Gruß,
! Pix[/i][/i][/i][/i][/i][/i][/i] -
Hi das hatten ich auch drin, aber es wird bei mir nichts in der Tabelle angezeigt.
-
Hi das hatten ich auch drin, aber es wird bei mir nichts in der Tabelle angezeigt. `
Was meinst du? -
Also ich habe nun ein zweites Skript eingefügt für das.
Wenn ich dieses Ausführe bekomme ich folgende Fehlermeldung im Log
javascript-0 2015-11-18 20:53:22 error at script.js.VIS_TV_Programm_jetzt:83:1 javascript-0 2015-11-18 20:53:22 error at TvProgrammEinlesen (script.js.VIS_TV_Programm_jetzt:27:40) javascript-0 2015-11-18 20:53:22 error script.js.VIS_TV_Programm_jetzt: TypeError: Cannot read property 'parseString' of undefined javascript-0 2015-11-18 20:53:22 error at TvProgrammEinlesen (script.js.VIS_TV_Programm_jetzt:27:23), at script.js.VIS_TV_Programm_jetzt:83:1 javascript-0 2015-11-18 20:53:22 error script.js.VIS_TV_Programm_jetzt: Cannot find module '/root/node_modules/iobroker.javascript/node_modules/xml2js' javascript-0 2015-11-18 20:53:22 info Start javascript script.js.VIS_TV_Programm_jetzt javascript-0 2015-11-18 20:53:22 info Stop script script.js.VIS_TV_Programm_jetzt
die selbe Fehlermeldung taucht auch beim Skript "VIS_TV_Programm" auf . Jetzt blicke ich gar nicht mehr durch
-
Hallo shortyle,
dieser Thread ist nicht der erste, der sich mit dem Thema beschäftigt. Vielleicht ist deshalb auch untergegangen, das du in den Einstellungen des Javascript-Adapters noch das node-Modul xml2js eintragen musst (unter zusätzliche npm-Module). Beim Speichern der Einstellungen wird das Modul installiert. Erst damit funktionieren die Skripte.
Gruß,
Pix
-
@pix:Hi das hatten ich auch drin, aber es wird bei mir nichts in der Tabelle angezeigt.
Was meinst du?
Hi ich meinte ich habe bei ID auch dieses drin :
javascript.1.TV_Programm.tvspielfilm.Tipps.json
Hab jetzt im Javascrict Aadapter auch noch xml2js eingetragen. aber trotzdem bleibt meine Tabelle leer.
-
Danke für den Tipp pix mit dem zusätzlichen Modul
Jetzt bin ich an dem gleichen Punkt wie audioconcept.
Im Log steht nun folgendes
javascript-0 2015-11-19 10:22:25 warn State "javascript.1.TV_Programm.tvspielfilm.jetzt.json" not found javascript-0 2015-11-19 10:22:25 warn State "javascript.1.TV_Programm.tvspielfilm.jetzt.xml" not found javascript-0 2015-11-19 10:22:24 info script.js.VIS_TV_Programm_jetzt: registered 1 subscription and 1 schedule javascript-0 2015-11-19 10:22:24 info Start javascript script.js.VIS_TV_Programm_jetzt javascript-0 2015-11-19 10:22:24 info Stop script script.js.VIS_TV_Programm_jetzt
Die Variablen sind aber korrekt erstellt und in den Objekten hinterlegt.
-
Hallo zusammen,
nutzt Ihr zwei für dieses Skript die javascript-Instanz 0 oder 1? Ich nutze für Skripte, die Daten aus dem Internet laden immer die Javascript Instanz javascript.1 , damit mir nicht die gesamte Javascript Steuerung abstürzt, wenn sich zB die Quellwebseite ändert und die Daten nicht mehr korrekt eingelesen werden können. Es gibt eine Trennung zwischen der wichtigen Haussteuerung und der unwichtigen Komfortfunktionen (TV Programm, Bus&Bahn, etc.).
Wenn ihr nur eine Javascript Instanz nutzt, müsst Ihr im Skript und in den VIS Datenpunkten "javascript.1" durch "javascript.0." ersetzen. Wenn ihr auch eine zweite Instanz anlegen wollt, dann einfach den Javascript-Adapter noch einmal installieren. In die Einstellungen dann noch den "xml2js" eintragen und dann in der Übersicht der Scripte das Skript auswählen und auf "javascript.1" umstellen.
Skript neu starten. Dann sollte es gehen.Gruß
Pix