3 # Rec10 TS Recording Tools
4 # Copyright (C) 2009-2010 Yukikaze
14 def wav2aac_nero(pin,pout):
15 os.environ['LANG']="ja_JP.UTF-8"
16 neroaac=configreader.getpath('NeroAAC')
17 exe=neroaac+" -br 128000 -2pass -if \""+pin+"\" -of \""+pout+"\""
19 txt=commands.getoutput(exe.encode('utf-8'))
20 recdblist.addlog(pin, exe, u"Wav2aac_Neroログ-コマンド")
21 recdblist.addlog(pin, txt, u"Wav2aac_Neroログ-詳細")
23 if not os.path.exists(pout):
25 exe=lame+" -b 128 \""+pin+"\" \""+pout+"\""
26 txt=commands.getoutput(exe.encode('utf-8'))
27 recdblist.addlog(pin, exe, u"Wav2aac_Lameログ-コマンド")
28 recdblist.addlog(pin, txt, u"Wav2aac_Lameログ-詳細")
29 def wav2mp3_lame(pin,pout):
30 os.environ['LANG']="ja_JP.UTF-8"
32 exe=lame+" -b 128 \""+pin+"\" \""+pout+"\""
34 txt=commands.getoutput(exe.encode('utf-8'))
37 recdblist.addlog(pin, exe, u"Wav2aac_Lameログ-コマンド")
38 recdblist.addlog(pin, txt, u"Wav2aac_Lameログ-詳細")
39 def ts2single_audio(pts):
40 paac=pts.replace(".ts",".aac")
41 ffmpeg=configreader.getpath("ffmpeg")
42 e0=ffmpeg+" -i \""+pts+"\" -y -vn -f aac -acodec copy \""+paac+"\""
43 p0=subprocess.Popen(e0,shell=True)
46 if os.path.exists(paac):
47 if os.path.getsize(paac)<1000:#1mで1kb以下の場合自動で終了
49 logt=unicode(p0.communicate()[0], "UTF-8")
50 recdblist.addlog(pts,e0, "FFmpeg音声取り出しログ-コマンド")
51 recdblist.addlog(pts,logt, "FFmpeg音声取り出しログ-詳細")
54 recdblist.Commonlogex("[Error]", "ffmpeg aac getting. (ts2single_audio@tv2audio.py)", u"AAC demux error(ffmpeg)", "", verbose_level=200, log_level=200)
55 os.kill(p0.pid,signal.SIGKILL)
57 ts2single_mp3_ffmpeg(pts)
58 if not os.path.exists(pts.replace(".ts",".mp3")):
59 ts2single_fp_BonTsDemux(pts)
61 logt=unicode(p0.communicate()[0], "UTF-8")
62 recdblist.addlog(pts,e0, "FFmpeg音声取り出しログ-コマンド")
63 recdblist.addlog(pts,logt, "FFmpeg音声取り出しログ-詳細")
66 logt=unicode(p0.communicate()[0], "UTF-8")
67 recdblist.addlog(pts,e0, "FFmpeg音声取り出しログ-コマンド")
68 recdblist.addlog(pts,logt, "FFmpeg音声取り出しログ-詳細")
71 recdblist.Commonlogex("[Error]", "ffmpeg aac getting. (ts2single_audio@tv2audio.py)", u"AAC demux error(ffmpeg)", "", verbose_level=200, log_level=200)
73 os.kill(p0.pid,signal.SIGKILL)
76 ts2single_mp3_ffmpeg(pts)
77 if not os.path.exists(pts.replace(".ts",".mp3")):
78 ts2single_fp_BonTsDemux(pts)
80 if os.path.exists(paac):
81 if os.path.getsize(paac)<1000:#1mで1kb以下の場合自動で終了
83 logt=unicode(p0.communicate()[0], "UTF-8")
84 recdblist.addlog(pts,e0, "FFmpeg音声取り出しログ-コマンド")
85 recdblist.addlog(pts,logt, "FFmpeg音声取り出しログ-詳細")
88 recdblist.Commonlogex("[Error]", "ffmpeg aac getting. (ts2single_audio@tv2audio.py)", u"AAC demux error(ffmpeg)", "", verbose_level=200, log_level=200)
90 ts2single_mp3_ffmpeg(pts)
91 if not os.path.exists(pts.replace(".ts",".mp3")):
92 ts2single_fp_BonTsDemux(pts)
95 logt=unicode(p0.communicate()[0], "UTF-8")
96 recdblist.addlog(pts,e0, "FFmpeg音声取り出しログ-コマンド")
97 recdblist.addlog(pts,logt, "FFmpeg音声取り出しログ-詳細")
102 logt=unicode(p0.communicate()[0], "UTF-8")
103 recdblist.addlog(pts,e0, "FFmpeg音声取り出しログ-コマンド")
104 recdblist.addlog(pts,logt, "FFmpeg音声取り出しログ-詳細")
107 recdblist.Commonlogex("[Error]", "ffmpeg aac getting. (ts2single_audio@tv2audio.py)", u"AAC demux error(ffmpeg)", "", verbose_level=200, log_level=200)
108 ts2single_mp3_ffmpeg(pts)
109 if not os.path.exists(pts.replace(".ts",".mp3")):
110 ts2single_fp_BonTsDemux(pts)
111 def ts2singlewav(pts,opts):
112 bontsdemux = configreader.getpath('bontsdemux')
113 bonpin = "Z:\\" + pts[1:]
114 outf = os.path.splitext(pts)[0]
115 bonpout = "Z:\\" + outf[1:]
116 xvfb = configreader.getpath('xvfb-run')
118 if re.search(",",opts):
120 exe = 'wine ' + bontsdemux + " -i \"" + bonpin + "\" -delay 167 -nd "+vf+"-sound 0 -o \"" + bonpout + "\" -start -quit"
121 #recdblist.printutf8(exe)
122 exe = xvfb + ' -a ' + exe
123 recdblist.printutf8(exe)
124 p=subprocess.Popen(exe.encode('utf-8'),shell=True)
126 logt=unicode(p.communicate()[0], "UTF-8")
127 recdblist.addCommandLog(ots, u"BonTsDemux 音声取り出し", exe, logt)
128 def ts2single_mp3_ffmpeg(pts):
129 pmp3=pts.replace(".ts",".mp3")
130 ffmpeg=configreader.getpath("ffmpeg")
131 e0=ffmpeg+" -i \""+pts+"\" -y -vn -ab 128k \""+pmp3+"\""
132 p0=subprocess.Popen(e0,shell=True)
133 os.waitpid(p0.pid, 0)
135 logt=unicode(p0.communicate()[0], "UTF-8")
136 recdblist.addlog(pts,e0, "FFmpeg_mp3音声取り出しログ-コマンド")
137 recdblist.addlog(pts,logt, "FFmpeg_mp3音声取り出しログ-詳細")
140 def ts2single_fp_BonTsDemux(pts):
143 if configreader.getpath("useNeroAAC")=="1" and os.path.exists(configreader.getpath("NeroAAC")):
148 ts2single_aac_BonTsDemux_Nero(pts)
150 ts2single_mp3_BonTsDemux(pts)
151 def ts2single_aac_BonTsDemux_Nero(pts):
153 aout=pts.replace(".ts",".aac")
154 ain=pts.replace(".ts",".wav")
155 tv2audio.wav2aac_nero(ain,aout)
156 def ts2single_mp3_BonTsDemux(pts):
158 aout=pts.replace(".ts",".mp3")
159 ain=pts.replace(".ts",".wav")
160 tv2audio.wav2mp3_lame(ain,aout)