我正在尝试编写一个脚本,可以将文件从网络服务器下载到内存,直接将其传送到ffmpeg的ffprobe模块,并返回由ffprobe确定的文件详细信息。这就是我目前所拥有的:
import requests
from io import BytesIO
from subprocess import Popen, PIPE
def get_file(url):
r = requests.get(url)
file = BytesIO(r.content).seek(0)
return file
def get_info(file):
p = Popen(["ffprobe", "-i", "-"], stdin=file, stdout=PIPE, stderr=PIPE)
output = p.communicate()[1].decode("utf8")
return output
以下是使用open():
加载的文件的输出之间的比较ffprobe version N-66931-gbbd8c85 Copyright (c) 2007-2014 the FFmpeg developers
built on Oct 17 2014 01:05:12 with gcc 4.9.1 (GCC)
configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-zlib
libavutil 54. 10.100 / 54. 10.100
libavcodec 56. 8.100 / 56. 8.100
libavformat 56. 9.100 / 56. 9.100
libavdevice 56. 1.100 / 56. 1.100
libavfilter 5. 1.106 / 5. 1.106
libswscale 3. 1.101 / 3. 1.101
libswresample 1. 1.100 / 1. 1.100
libpostproc 53. 3.100 / 53. 3.100
Input #0, mp3, from 'pipe:':
Metadata:
title : Test File
Duration: N/A, start: 0.000000, bitrate: 320 kb/s
Stream #0:0: Audio: mp3, 44100 Hz, stereo, s16p, 320 kb/s
Metadata:
title : Test File
...以及使用get_file()下载的文件:
ffprobe version N-66931-gbbd8c85 Copyright (c) 2007-2014 the FFmpeg developers
built on Oct 17 2014 01:05:12 with gcc 4.9.1 (GCC)
configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-zlib
libavutil 54. 10.100 / 54. 10.100
libavcodec 56. 8.100 / 56. 8.100
libavformat 56. 9.100 / 56. 9.100
libavdevice 56. 1.100 / 56. 1.100
libavfilter 5. 1.106 / 5. 1.106
libswscale 3. 1.101 / 3. 1.101
libswresample 1. 1.100 / 1. 1.100
libpostproc 53. 3.100 / 53. 3.100
pipe:: Not enough space
首先,这看起来像内存不足的问题,但我正在使用的文件很小(<10MB),所以我不认为这是问题。显然,我做错了什么......有人可以给我任何关于为什么管道会在这种情况下失败的建议吗?
答案 0 :(得分:1)
显然这不是一个可重现的错误,因为我刚回去,尝试了相同的代码,它神奇地起作用。我认为“没有足够的空间”错误可能是由于当时正在进行内存密集的事情造成的,导致我无法将文件传递给ffmpeg。我不记得我试图加载的文件,但如果它已经很大,我可以看到路障如何被击中。流式数据无疑是明智的,而不是试图将其全部加载到内存中。
无论哪种方式,现在一切都是copacetic!