我正在编写一个脚本来提取视频关键帧(到frame_{0}.jpg
(和音频到一个单独的.mp3
文件中。这是我到目前为止所拥有的:
import os
import av
path_to_video = 'http://184.72.239.149/vod/smil:BigBuckBunny.smil/playlist.m3u8'
container = av.open(path_to_video)
stream = container.streams.video[0]
audio_stream = container.streams.audio[0]
stream.codec_context.skip_frame = 'NONKEY'
tgt_path = "./frames"
if not os.path.isdir(tgt_path):
os.makedirs(tgt_path)
for frame in container.decode(stream):
tgt_filename = os.path.join(tgt_path,'frame-{:09d}.jpg'.format(frame.pts))
frame.to_image().save(tgt_filename,quality=80)
如何将音频流保存到文件(最好是块(。我是否需要启动单独的捕获例程并并行运行,或者我可以在上述循环中捕获?
不幸的是,我查看了pyav github的帖子,但没有运气。不知道我如何在一个循环中做到这一点。
这是
来自pyav github存储库上发布的答案:
import av
input_container = av.open(
'http://184.72.239.149/vod/smil:BigBuckBunny.smil/playlist.m3u8')
input_stream = input_container.streams.get(audio=0)[0]
output_container = av.open('live_stream.mp3', 'w')
output_stream = output_container.add_stream('mp3')
for frame in input_container.decode(input_stream):
frame.pts = None
for packet in output_stream.encode(frame):
output_container.mux(packet)
for packet in output_stream.encode(None):
output_container.mux(packet)
output_container.close()