From 4c2a71762226fee925f9f9b4b0199bb7e8da0386 Mon Sep 17 00:00:00 2001 From: lionel G Date: Wed, 4 May 2016 16:44:17 +0200 Subject: [PATCH] First attempt to clean things --- podcast.py | 64 ++++++++++++++++++++---------------------------------- 1 file changed, 24 insertions(+), 40 deletions(-) diff --git a/podcast.py b/podcast.py index 573db04..64d4c89 100755 --- a/podcast.py +++ b/podcast.py @@ -4,37 +4,15 @@ import pycurl,sys,taglib,signal,os +# Based on the old 'download.py' that was used for one show +# TODO : +# - lire les .xml dans rss/ et afficher la liste des disponibles +# - ajouter les options en ligne de commande pour choisir l'émission +# - touch des fichiers télécharger dans archives/emissions/xx +# - commande pour rafraichir les fichiers xml en fonction des *.url -#<item> -#<title>Le moment Meurice 28.10.2015 -#http://www.radiofrance.fr/ -#durée : 00:05:12 - SI TU ECOUTES J'ANNULE TOUT - par : Guillaume MEURICE -#podcast@radiofrance.com -#News & Politics -# -#http://media.radiofrance-podcast.net/podcast09/13942-28.10.2015-ITEMA_20827962-4.mp3 -#Wed, 28 Oct 2015 17:30:00 +0100 -#23173 -#2015F23173S0301 -#11341456 -#Guillaume MEURICE -#no -#Le,moment,Meurice,28.10.2015 -#Émission du 28.10.2015 -#durée : 00:05:12 - par : Guillaume MEURICE -#00:05:12 -# - - -# Seul nous intéresse : - # title as titre - # description as description - # guid as guid - # itunes:subtitle as subtitle - # itunes:duration as duration - # pubDate as pudDate (Fri, 30 Oct 2015 17:50:00 +0100) - +# Classe toute bête pour stocker les propriétés d'un mp3 class item: titre = None description = None @@ -42,19 +20,25 @@ class item: pudDate = None duration = None + # Ci-dessous : est-ce vraiment utile si on ne fait rien à l'init ? def __init__(self): pass +# Classe emission : il faut lui passer l'emission issue de la ligne de commande class emmission: __currentNode__ = None __itemsList__ = None - def __init__(self): - self.readXml() + def __init__(self, xmlfile): + self.readXml(xmlfile) - def readXml(self): + def readXml(self, xmlfile): from xml.dom.minidom import parse - self.doc = parse('rss_13942.xml') + try: + self.doc = parse(xmlfile) + except: + print("XML file not found") + sys.exit(1) def getRootElement(self): if self.__currentNode__ == None: @@ -85,11 +69,12 @@ class emmission: def getText(self, node): return node.childNodes[0].nodeValue +# Ca fait quoi cette fonction ? def signal_handler(signal, frame): sys.stdout.write("\n") sys.exit(0) - +# Ecrire les id3 def tagid3(file,jour,mois,annee): # {'ALBUM': ['Le moment Meurice'], # OU @@ -106,7 +91,7 @@ def tagid3(file,jour,mois,annee): # 'TITLE': ['Le moment Meurice 13.11.2015'], # OU # 'TITLE': ['Chasse au pinson 11.11.2015'], -# 'LENGTH': ['00h05m17s']} +# 'LENGTH': ['00h05m17s']} retval = 1 @@ -131,11 +116,11 @@ if __name__ == "__main__": # fenetre.move(0,0) # fenetre.addch('*') # prévoit l'écriture de '*' à la position du curseur # fenetre.refresh() # écrit réellement ce qui a été prévu par addch() et addstr() -# time.sleep(2) # attend deux secondes avant de... +# time.sleep(2) # attend deux secondes - x=emmission() - items=x.getitems() + x = emmission() + items = x.getitems() nb_items = len(items) j = 0 @@ -158,7 +143,7 @@ if __name__ == "__main__": with open(name, 'wb') as f: c = pycurl.Curl() c.setopt(c.URL, str(i.guid)) - c.setopt(c.WRITEDATA, f) + c.setopt(c.WRITEDATA, f) c.setopt(c.MAXREDIRS, 5) c.setopt(c.NOPROGRESS, 1) c.setopt(c.CONNECTTIMEOUT, 30) @@ -190,4 +175,3 @@ if __name__ == "__main__": # c.perform() # c.close() # sys.stdout.write("\nDone.\n") - -- 2.39.5