mirror of
https://github.com/kkroening/ffmpeg-python.git
synced 2025-04-06 04:15:44 +08:00
commit
7077eaad64
@ -1,9 +1,10 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from . import _filters, _ffmpeg, _run
|
from . import _filters, _ffmpeg, _run, _probe
|
||||||
from ._filters import *
|
from ._filters import *
|
||||||
from ._ffmpeg import *
|
from ._ffmpeg import *
|
||||||
from ._run import *
|
from ._run import *
|
||||||
from ._view import *
|
from ._view import *
|
||||||
|
from ._probe import *
|
||||||
|
|
||||||
__all__ = _filters.__all__ + _ffmpeg.__all__ + _run.__all__ + _view.__all__
|
__all__ = _filters.__all__ + _ffmpeg.__all__ + _run.__all__ + _view.__all__ + _probe.__all__
|
||||||
|
29
ffmpeg/_probe.py
Executable file
29
ffmpeg/_probe.py
Executable file
@ -0,0 +1,29 @@
|
|||||||
|
import json
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
|
||||||
|
class ProbeException(Exception):
|
||||||
|
def __init__(self, stderr_output):
|
||||||
|
super(ProbeException, self).__init__('ffprobe error')
|
||||||
|
self.stderr_output = stderr_output
|
||||||
|
|
||||||
|
|
||||||
|
def probe(filename):
|
||||||
|
"""Run ffprobe on the specified file and return a JSON representation of the output.
|
||||||
|
|
||||||
|
Raises:
|
||||||
|
ProbeException: if ffprobe returns a non-zero exit code, a ``ProbeException`` is returned with a generic error
|
||||||
|
message. The stderr output can be retrieved by accessing the ``stderr_output`` property of the exception.
|
||||||
|
"""
|
||||||
|
args = ['ffprobe', '-show_format', '-show_streams', '-of', 'json', filename]
|
||||||
|
p = subprocess.Popen(args, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
||||||
|
out, err = p.communicate()
|
||||||
|
if p.returncode != 0:
|
||||||
|
raise ProbeException(err)
|
||||||
|
return json.loads(out.decode('utf-8'))
|
||||||
|
|
||||||
|
|
||||||
|
__all__ = [
|
||||||
|
'probe',
|
||||||
|
'ProbeException',
|
||||||
|
]
|
@ -16,6 +16,7 @@ TEST_INPUT_FILE1 = os.path.join(SAMPLE_DATA_DIR, 'in1.mp4')
|
|||||||
TEST_OVERLAY_FILE = os.path.join(SAMPLE_DATA_DIR, 'overlay.png')
|
TEST_OVERLAY_FILE = os.path.join(SAMPLE_DATA_DIR, 'overlay.png')
|
||||||
TEST_OUTPUT_FILE1 = os.path.join(SAMPLE_DATA_DIR, 'out1.mp4')
|
TEST_OUTPUT_FILE1 = os.path.join(SAMPLE_DATA_DIR, 'out1.mp4')
|
||||||
TEST_OUTPUT_FILE2 = os.path.join(SAMPLE_DATA_DIR, 'out2.mp4')
|
TEST_OUTPUT_FILE2 = os.path.join(SAMPLE_DATA_DIR, 'out2.mp4')
|
||||||
|
BOGUS_INPUT_FILE = os.path.join(SAMPLE_DATA_DIR, 'bogus')
|
||||||
|
|
||||||
|
|
||||||
subprocess.check_call(['ffmpeg', '-version'])
|
subprocess.check_call(['ffmpeg', '-version'])
|
||||||
@ -432,3 +433,16 @@ def test_pipe():
|
|||||||
out_data = p.stdout.read()
|
out_data = p.stdout.read()
|
||||||
assert len(out_data) == frame_size * (frame_count - start_frame)
|
assert len(out_data) == frame_size * (frame_count - start_frame)
|
||||||
assert out_data == in_data[start_frame*frame_size:]
|
assert out_data == in_data[start_frame*frame_size:]
|
||||||
|
|
||||||
|
|
||||||
|
def test_ffprobe():
|
||||||
|
data = ffmpeg.probe(TEST_INPUT_FILE1)
|
||||||
|
assert set(data.keys()) == {'format', 'streams'}
|
||||||
|
assert data['format']['duration'] == '7.036000'
|
||||||
|
|
||||||
|
|
||||||
|
def test_ffprobe_exception():
|
||||||
|
with pytest.raises(ffmpeg.ProbeException) as excinfo:
|
||||||
|
ffmpeg.probe(BOGUS_INPUT_FILE)
|
||||||
|
assert str(excinfo.value) == 'ffprobe error'
|
||||||
|
assert b'No such file or directory' in excinfo.value.stderr_output
|
||||||
|
Loading…
x
Reference in New Issue
Block a user