3 # Rec10 TS Recording Tools
4 # Copyright (C) 2009-2010 Yukikaze
19 path = str(os.path.dirname(os.path.abspath(__file__))) + "/"
20 tmppath = configreader.getpath("tmp")+"/"
24 recdblist.printutf8(chtxt)
25 tnow = datetime.datetime.now()
27 lastup = datetime.datetime.strptime(chdb.chtxtsearch(chtxt)[0]['update'], "%Y-%m-%d %H:%M:%S")
29 lastup = datetime.datetime.strptime("2009-04-01 00:00:00", "%Y-%m-%d %H:%M:%S")
31 dt = dt.days * 24 * 60 + dt.seconds
33 ts2epg.write(os.path.join(tmppath, chtxt + "epgdata.xml"), chdb.chtxtsearch(chtxt)['ch'])
34 xml2db_dom.xml2db_dom(os.path.join(tmppath, chtxt + "epgdata.xml"), chdb.chtxtsearch(chtxt)['bctype'])
36 bctypel = chdb.bctypesearch(bctype)
39 ts2epg.write(tmppath + bctype + "epgdata.xml", chdb.bctypesearch(bctype)['ch'])
40 xml2db_dom.xml2db_dom(tmppath + bctype + "epgdata.xml", bctype)
41 shutil.copyfile(tmppath + bctype + "epgdata.xml", tmppath + bctype + "epgdata.bak.xml")
43 rec10d.rec10db.update_by_bctype_epg_ch(bctype)
44 except Exception, inst:
45 recdblist.Commonlogex("Error","updatebc(epgdb.py)", str(type(inst)), str(inst)+"\n"+traceback.format_exc(),log_level=200)
46 xml2db_dom.xml2db_dom(tmppath + bctype + "epgdata.bak.xml", bctype)
47 rec10d.rec10db.update_status_by_bctype_epg_ch(bctype, "2")
48 def updatebc_bak(bctype):
50 update epg data by .bak file
52 xml2db_dom.xml2db_dom(tmppath + bctype + "epgdata.bak.xml", bctype)
53 def searchtime2(titletxt, timet, deltatime, chtxt):
54 time = datetime.datetime.strptime(timet, "%Y-%m-%d %H:%M:%S")
56 deltatime = int(deltatime)
57 beforetime = time.strftime("%Y%m%d%H%M%S")
58 beforetime = time - datetime.timedelta(hours=deltatime)
59 aftertime = time + datetime.timedelta(hours=deltatime)
60 beforetime = beforetime.strftime("%Y%m%d%H%M%S")
61 aftertime = aftertime.strftime("%Y%m%d%H%M%S")
62 one = ["", "", "", "","","",""]
64 chtxtt=chtxt.replace("_0","_%")
65 d = rec10d.rec10db.select_by_time_ngram_epg_timeline(beforetime, aftertime, chtxtt)
66 for chtxtt, title, start, stop ,exp,longexp,category in d:
67 #recdblist.printutf8(chtxtt+":"+title+":"+start+":"+stop)
68 p = n_gram.bigram(titletxt, title)
70 btime = btime[0:4] + "-" + btime[4:6] + "-" + btime[6:8] + " " + btime[8:10] + ":" + btime[10:12] + ":00"
72 etime = etime[0:4] + "-" + etime[4:6] + "-" + etime[6:8] + " " + etime[8:10] + ":" + etime[10:12] + ":00"
73 bt = datetime.datetime.strptime(btime, "%Y-%m-%d %H:%M:%S")
76 dt = 24 * 60 * 60 * dt.days + dt.seconds + 1
78 dt = 1000-1000 * dt / (7 * 24 * 60 * 60)
82 one = [chtxtt, title, btime, etime,exp,longexp,category]
85 #recdblist.printutf8(title + ":" + str(p) + u"点")
90 def searchtime_auto(keytxt, timet, deltatime):
91 time = datetime.datetime.strptime(timet, "%Y-%m-%d %H:%M:%S")
93 deltatime = int(deltatime)
94 beforetime = time.strftime("%Y%m%d%H%M%S")
95 aftertime = time + datetime.timedelta(hours=deltatime)
96 aftertime = aftertime.strftime("%Y%m%d%H%M%S")
97 d = rec10d.rec10db.select_by_time_keyword_auto_suggest_epg_timeline(keytxt,beforetime, aftertime)
98 for chtxtt, title, start, stop ,exp,longexp,category in d:
100 btime = btime[0:4] + "-" + btime[4:6] + "-" + btime[6:8] + " " + btime[8:10] + ":" + btime[10:12] + ":00"
102 etime = etime[0:4] + "-" + etime[4:6] + "-" + etime[6:8] + " " + etime[8:10] + ":" + etime[10:12] + ":00"
103 ret.append([chtxtt, title, btime, etime,exp,longexp,category])
105 def count_schedule(btime,etime):
107 return rec num (int return[0]:TE /int return[1]:BS/CS)
118 dls = rec10d.rec10db.select_bytime_all_timeline(btime, etime)
120 btd = datetime.datetime.strptime(btime, "%Y-%m-%d %H:%M:%S")
121 etd = datetime.datetime.strptime(etime, "%Y-%m-%d %H:%M:%S")
123 dd1 = datetime.datetime.strptime(dl['btime'], "%Y-%m-%d %H:%M:%S")
124 dd2 = datetime.datetime.strptime(dl['etime'], "%Y-%m-%d %H:%M:%S")
131 times = list(set(times))
135 for i in xrange(0, len(times)-2, 1):
138 btime1 = bt1.strftime("%Y-%m-%d %H:%M:%S")
139 etime1 = et1.strftime("%Y-%m-%d %H:%M:%S")
140 ret1 = rec10d.rec10db.count_schedule_timeline(btime1, etime1)
141 if retcount[0] < ret1[0]:
142 retcount[0] = ret1[0]
143 if retcount[1] < ret1[1]:
144 retcount[1] = ret1[1]
147 def search_schedule(btime,etime):
149 return rec num (int return[0]:TE /int return[1]:BS/CS)
160 dls = rec10d.rec10db.select_bytime_all_timeline(btime, etime)
162 btd = datetime.datetime.strptime(btime, "%Y-%m-%d %H:%M:%S")
163 etd = datetime.datetime.strptime(etime, "%Y-%m-%d %H:%M:%S")
165 dd1 = datetime.datetime.strptime(dl['btime'], "%Y-%m-%d %H:%M:%S")
166 dd2 = datetime.datetime.strptime(dl['etime'], "%Y-%m-%d %H:%M:%S")
173 times = list(set(times))
177 for i in xrange(0, len(times)-2, 1):
180 btime1 = bt1.strftime("%Y-%m-%d %H:%M:%S")
181 etime1 = et1.strftime("%Y-%m-%d %H:%M:%S")
182 ret1 = rec10d.rec10db.search_schedule_timeline(btime1, etime1)
187 def count_epgschedule(epgbtime,epgetime):
189 return rec num (int return[0]:TE /int return[1]:BS/CS)
200 dls = rec10d.rec10db.select_byepgtime_over_timeline(epgbtime, epgetime)
203 btd = datetime.datetime.strptime(epgbtime, "%Y-%m-%d %H:%M:%S")
204 etd = datetime.datetime.strptime(epgetime, "%Y-%m-%d %H:%M:%S")
206 dd1 = datetime.datetime.strptime(dl['epgbtime'], "%Y-%m-%d %H:%M:%S")
207 dd2 = datetime.datetime.strptime(dl['epgetime'], "%Y-%m-%d %H:%M:%S")
214 times = list(set(times))
218 for i in xrange(0, len(times)-1, 1):
221 epgbtime1 = bt1.strftime("%Y-%m-%d %H:%M:%S")
222 epgetime1 = et1.strftime("%Y-%m-%d %H:%M:%S")
223 ret1 = rec10d.rec10db.count_epgschedule_timeline(epgbtime1, epgetime1)
224 if retcount[0] < ret1[0]:
225 retcount[0] = ret1[0]
226 if retcount[1] < ret1[1]:
227 retcount[1] = ret1[1]
229 def search_epgschedule(epgbtime,epgetime):
231 return rec num (int return[0]:TE /int return[1]:BS/CS)
242 dls = rec10d.rec10db.select_byepgtime_all_timeline(epgbtime, epgetime)
244 btd = datetime.datetime.strptime(epgbtime, "%Y-%m-%d %H:%M:%S")
245 etd = datetime.datetime.strptime(epgetime, "%Y-%m-%d %H:%M:%S")
247 dd1 = datetime.datetime.strptime(dl['epgbtime'], "%Y-%m-%d %H:%M:%S")
248 dd2 = datetime.datetime.strptime(dl['epgetime'], "%Y-%m-%d %H:%M:%S")
255 times = list(set(times))
259 for i in xrange(0, len(times)-2, 1):
262 epgbtime1 = bt1.strftime("%Y-%m-%d %H:%M:%S")
263 epgetime1 = et1.strftime("%Y-%m-%d %H:%M:%S")
264 ret1 = rec10d.rec10db.search_epgschedule_timeline(epgbtime1, epgetime1)