OSDN Git Service

fix some bugs.
[rec10/rec10-git.git] / rec10 / trunk / src / scan_ch.py
index 6b4462b..5b79cf2 100644 (file)
@@ -1,59 +1,78 @@
 #!/usr/bin/python
 # coding: UTF-8
 # Rec10 TS Recording Tools
-# Copyright (C) 2009-2010 Yukikaze
+# Copyright (C) 2009-2011 Yukikaze
 import os
 import os.path
 import time
 import commands
+import traceback
+import datetime
 
+import chdb
 import rec10d
 import configreader
 import recdblist
 import tv2ts
-tmppath = configreader.getpath("tmp")+"/"
-tssplitterp = configreader.getpath("tssplitter")
+tmppath = configreader.getConfPath("tmp")+"/"
+tssplitterp =configreader.getConfPath("java")+" -jar "+configreader.getConfPath("jTsSplitter")
 def searchCh():
+    rec10d.rec10db.change_installed_in_status(2)
     #地上デジタル
-    for i in xrange(12,99):
+    for i in xrange(13,62):#62
         recdblist.printuft8ex(u"チャンネルスキャン:地上デジタル CH "+str(i), 200, 200)
         if checkTs(str(i))>0:
             addCh(str(i),u"te"+str(i),str(i))
+    time.sleep(1)
     #BSデジタル
-    recdblist.printuft8ex(u"チャンネルスキャン:BSデジタル "+str(i), 200, 200)
-    for i in xrange(100,240):
+    recdblist.printuft8ex(u"チャンネルスキャン:BSデジタル ", 200, 200)
+    for i in xrange(100,280):#240
         recdblist.printuft8ex(u"チャンネルスキャン:BSデジタル CH "+str(i), 200, 200)
         if checkTs(str(i))>0:
             addCh(str(i),u"bs","BS")
+    time.sleep(1)
     #スカパーe2!
     #http://www5e.biglobe.ne.jp/~kazu_f/digital-sat/trapon-nsat110.html
     #
     #CS1ネットワーク
     if checkTs("CS2")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS2 ", 200, 200)
         addCh("CS2","cs1","CS")
     if checkTs("CS8")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS8", 200, 200)
         addCh("CS8","cs1","CS")
     if checkTs("CS10")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS10", 200, 200)
         addCh("CS10","cs1","CS")
     #CS2ネットワーク
     if checkTs("CS4")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS4", 200, 200)
         addCh("CS4","cs2","CS")
     if checkTs("CS6")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS6", 200, 200)
         addCh("CS6","cs2","CS")
     if checkTs("CS12")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS12", 200, 200)
         addCh("CS12","cs2","CS")
     if checkTs("CS14")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS14", 200, 200)
         addCh("CS14","cs2","CS")
     if checkTs("CS16")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS16", 200, 200)
         addCh("CS16","cs2","CS")
     if checkTs("CS18")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS18", 200, 200)
         addCh("CS18","cs2","CS")
     if checkTs("CS20")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS20", 200, 200)
         addCh("CS20","cs2","CS")
     if checkTs("CS22")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS22", 200, 200)
         addCh("CS22","cs2","CS")
     if checkTs("CS24")>0:
+        recdblist.printuft8ex(u"チャンネルスキャン:CSSデジタル CH:CS24", 200, 200)
         addCh("CS24","cs2","CS")
+    rec10d.rec10db.change_installed_in_status(100)
 def checkTs(ch):
     tv2ts.tv2b25ts(os.path.join(tmppath,"ch_"+str(ch)+".ts"), ch, "1")
     if os.path.exists(os.path.join(tmppath,"ch_"+str(ch)+".ts")):
@@ -62,25 +81,38 @@ def checkTs(ch):
     else:
         return 0
 def addCh(ch,bctype,chtxthead):
-    prglist=getChProgNum(ch)
-    for lstr in prglist:
+    prglist=getChProgNum(ch)##[prglist,logt]
+    for lstr in prglist[0]:
         #print [bctype,chtxthead+"_"+lstr, ch, lstr]
         try:
-            rec10d.rec10db.add_epg_ch(bctype,chtxthead+"_"+lstr, ch, lstr, u"2010-01-01 00:00:00")
+            if ch.find("bs")>-1:
+                if int(lstr)<300:
+                    tnow=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
+                    rec10d.rec10db.add_epg_ch(bctype,chtxthead+"_"+lstr, ch, lstr, u"2010-01-01 00:00:00", u"2010-01-01 00:00:00",tnow)
+            else:
+                tnow=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
+                rec10d.rec10db.add_epg_ch(bctype,chtxthead+"_"+lstr, ch, lstr, u"2010-01-01 00:00:00", u"2010-01-01 00:00:00",tnow)
         except Exception, inst:
-            recdblist.Commonlogex("Warning", "addCh (scan_ch.py)", str(type(inst)),str(inst)+traceback.format_exc(),log_level=200)
+            recdblist.addCommonlogEX("Warning", "addCh (scan_ch.py)", str(type(inst)),str(inst)+traceback.format_exc(),log_level=200)
+    checkB25Purchased(ch, prglist[1])
 def getChProgNum(ch):
     pout=os.path.join(tmppath,"ch_"+str(ch)+".ts")
-    tv2ts.tv2tsmix(pout, ch, "10")
-    retl=getTsProgNum(pout)
+    logt=tv2ts.tv2tsmix(pout, ch, "10")
+    retl=getTsProgNum(ch,pout)
     os.remove(pout)
-    return retl
-def getTsProgNum(tspath):
+    return [retl,logt]
+def getTsProgNum(ch,tspath):
     pin=tspath
     pout=os.path.join(tmppath,"chscan.txt")
-    doexe = tssplitterp + " -ch \""+ pin + "\" \""+ pout + "\""
+    chopt="-ch"
+    if ch.find("CS")>-1:
+        chopt="-cs"
+    elif int(ch)>99:
+        chopt="-bs"
+    doexe = tssplitterp + " "+chopt+" \""+ pin + "\" \""+ pout + "\""
     doexe = "nice -n 18 " + doexe
     os.environ['LANG']="ja_JP.UTF-8"
+    os.system(u"touch \""+pout+"\"")
     txt = unicode(commands.getoutput(doexe.encode('utf-8')),'utf-8','ignore')
     f=open(pout)
     lines=f.readlines()
@@ -93,12 +125,34 @@ def getTsProgNum(tspath):
             ret.append(str(int(l)))
         except:
             ""
-    recdblist.addlog(pin, doexe, u"TsSplitログ-コマンド")
-    recdblist.addlog(pin, txt, u"TsSplitログ-詳細")
+    recdblist.addLog(pin, doexe, u"TsSplitログ-コマンド")
+    recdblist.addLog(pin, txt, u"TsSplitログ-詳細")
     time.sleep(1)
     try:
         ""
         #os.remove(pout)
     except:
         ""
-    return ret
\ No newline at end of file
+    return ret
+def getB25UnparchasedList(logtxt):
+    warning = 0
+    ret=[]
+    for strt in logtxt.splitlines():
+        if strt.find("unpurchased ECM")>-1:
+            warning=1
+        if strt.find("total TS packet")>-1 and warning>0:
+            warning=0
+        if strt.find("channel")>-1 and warning>0:
+            txt=strt.replace("channel:","")
+            txt=txt.replace("\n","")
+            txt=txt.replace(" ","")
+            ret.append(txt)
+    return ret
+def checkB25Purchased(ch,logtxt):
+    chlists=chdb.searchAllCHFromCh(ch)
+    upl=getB25UnparchasedList(logtxt)
+    if len(upl)>0 and len(chlists)>0:
+        for chl in chlists:
+            if chl != None:
+                if chl['csch'] in upl:
+                    chdb.changeCHShow(chl['chtxt'],"0")