Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. XML Daten (TV Programm) in ioBroker

    NEWS

    • Update NodeJS best practise, supported 14, 16 und 18!

    • Bestätigt/Acknowledged-Flag Bedeutung - ein Mysterium ;-)

    • Update js-controller 4.0.24 (Stable)

    XML Daten (TV Programm) in ioBroker

    This topic has been deleted. Only users with topic management privileges can see it.
    • P
      pix last edited by

      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_TVProgramm

      
      Warum 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&amp;t=2821#p25427](http://forum.iobroker.net/viewtopic.php?f=20&amp;t=2821#p25427)[/i][/i][/i][/i][/i][/i][/i][/code][/i][/i][/i][/i][/i][/i][/i][/i]
      ```
      1 Reply Last reply Reply Quote 0
      • Bluefox
        Bluefox last edited by

        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.

        1 Reply Last reply Reply Quote 0
        • P
          pix last edited by

          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 Programm

          bringt 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="&quot; + result.rss.channel.item[i].enclosure.url + &quot;">");
          
                          }
          
                      }
                  });
              } else  {
                  log(error);
              }
          });   // Ende request 
          log('XML-Daten aus TV Spielfilm eingelesen');
          

          });</result.rss.channel.item.length;i++)>`

          Und die Objekte:
          261_bildschirmfoto_2015-06-23_um_19.36.17.jpg

          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] 261_bildschirmfoto_2015-06-23_um_19.56.34.jpg [/spoiler][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/i][/code][/i]

          1 Reply Last reply Reply Quote 0
          • Bluefox
            Bluefox last edited by

            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 Programm

            bringt 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]

            1 Reply Last reply Reply Quote 0
            • P
              pix last edited by

              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

              1 Reply Last reply Reply Quote 0
              • Bluefox
                Bluefox last edited by

                Bitte updaten auf js-controller 0.7.1 und vis 0.6.1

                1 Reply Last reply Reply Quote 0
                • P
                  pix last edited by

                  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:
                  261_bildschirmfoto_2015-11-18_um_14.42.29.jpg
                  ! Gruß
                  ! Pix[/i][/i][/i][/i][/i][/i][/i][/i]

                  1 Reply Last reply Reply Quote 0
                  • A
                    audioconcept last edited by

                    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]
                    
                    1 Reply Last reply Reply Quote 0
                    • P
                      pix last edited by

                      Im Reiter rechts auf css Projekt einfügen.

                      Gesendet von meinem iPhone mit Tapatalk

                      1 Reply Last reply Reply Quote 0
                      • A
                        audioconcept last edited by

                        Hi oh hatte das übersehen.

                        Alles andere ist so weit richtig?

                        Was nimmst du denn bei "Table Objekt ID"?

                        1 Reply Last reply Reply Quote 0
                        • S
                          shortyle last edited by

                          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

                          1 Reply Last reply Reply Quote 0
                          • P
                            pix last edited by

                            @audioconcept:

                            Was nimmst du denn bei "Table Objekt ID"? `
                            javascript.1.TV_Programm.tvspielfilm.Tipps.json

                            Pix

                            1 Reply Last reply Reply Quote 0
                            • P
                              pix last edited by

                              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]

                              1 Reply Last reply Reply Quote 0
                              • A
                                audioconcept last edited by

                                Hi das hatten ich auch drin, aber es wird bei mir nichts in der Tabelle angezeigt.

                                1 Reply Last reply Reply Quote 0
                                • P
                                  pix last edited by

                                  @audioconcept:

                                  Hi das hatten ich auch drin, aber es wird bei mir nichts in der Tabelle angezeigt. `
                                  Was meinst du?

                                  1 Reply Last reply Reply Quote 0
                                  • S
                                    shortyle last edited by

                                    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

                                    1 Reply Last reply Reply Quote 0
                                    • P
                                      pix last edited by

                                      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

                                      1 Reply Last reply Reply Quote 0
                                      • A
                                        audioconcept last edited by

                                        @pix:

                                        @audioconcept:

                                        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.

                                        1 Reply Last reply Reply Quote 0
                                        • S
                                          shortyle last edited by

                                          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.

                                          1 Reply Last reply Reply Quote 0
                                          • P
                                            pix last edited by

                                            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.
                                            261_bildschirmfoto_2015-11-20_um_00.01.40.jpg
                                            Skript neu starten. Dann sollte es gehen.

                                            Gruß

                                            Pix

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.5k
                                            Online

                                            29.0k
                                            Users

                                            63.1k
                                            Topics

                                            963.2k
                                            Posts

                                            8
                                            42
                                            10701
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2021
                                            logo