2010-02-21 11:43:01 +00:00
|
|
|
\input texinfo @c -*- texinfo -*-
|
|
|
|
|
2011-04-23 15:19:17 +02:00
|
|
|
@settitle ffprobe Documentation
|
2010-02-21 11:43:01 +00:00
|
|
|
@titlepage
|
2011-04-23 15:19:17 +02:00
|
|
|
@center @titlefont{ffprobe Documentation}
|
2010-02-21 11:43:01 +00:00
|
|
|
@end titlepage
|
|
|
|
|
2011-01-29 13:24:13 +01:00
|
|
|
@top
|
|
|
|
|
|
|
|
@contents
|
|
|
|
|
2010-06-08 22:32:29 +00:00
|
|
|
@chapter Synopsis
|
|
|
|
|
|
|
|
The generic syntax is:
|
|
|
|
|
|
|
|
@example
|
|
|
|
@c man begin SYNOPSIS
|
|
|
|
ffprobe [options] [@file{input_file}]
|
|
|
|
@c man end
|
|
|
|
@end example
|
|
|
|
|
2010-06-03 21:23:05 +00:00
|
|
|
@chapter Description
|
2010-02-21 11:43:01 +00:00
|
|
|
@c man begin DESCRIPTION
|
|
|
|
|
2011-04-23 16:40:01 +02:00
|
|
|
ffprobe gathers information from multimedia streams and prints it in
|
2010-02-21 11:43:01 +00:00
|
|
|
human- and machine-readable fashion.
|
|
|
|
|
|
|
|
For example it can be used to check the format of the container used
|
|
|
|
by a multimedia stream and the format and type of each media stream
|
|
|
|
contained in it.
|
|
|
|
|
|
|
|
If a filename is specified in input, ffprobe will try to open and
|
|
|
|
probe the file content. If the file cannot be opened or recognized as
|
|
|
|
a multimedia file, a positive exit code is returned.
|
|
|
|
|
2011-04-23 16:40:01 +02:00
|
|
|
ffprobe may be employed both as a standalone application or in
|
2010-02-21 11:43:01 +00:00
|
|
|
combination with a textual filter, which may perform more
|
|
|
|
sophisticated processing, e.g. statistical processing or plotting.
|
|
|
|
|
|
|
|
Options are used to list some of the formats supported by ffprobe or
|
|
|
|
for specifying which information to display, and for setting how
|
|
|
|
ffprobe will show it.
|
|
|
|
|
2011-04-23 16:40:01 +02:00
|
|
|
ffprobe output is designed to be easily parsable by a textual filter,
|
2011-10-02 11:59:38 +02:00
|
|
|
and consists of one or more sections of a form defined by the selected
|
|
|
|
writer, which is specified by the @option{print_format} option.
|
2010-02-21 11:43:01 +00:00
|
|
|
|
|
|
|
Metadata tags stored in the container or in the streams are recognized
|
2011-10-02 11:59:38 +02:00
|
|
|
and printed in the corresponding "FORMAT" or "STREAM" section.
|
2010-02-21 11:43:01 +00:00
|
|
|
|
|
|
|
@c man end
|
|
|
|
|
2010-06-08 22:32:29 +00:00
|
|
|
@chapter Options
|
2010-02-21 11:43:01 +00:00
|
|
|
@c man begin OPTIONS
|
|
|
|
|
2011-09-02 22:17:38 +02:00
|
|
|
@include avtools-common-opts.texi
|
2010-02-21 11:43:01 +00:00
|
|
|
|
|
|
|
@section Main options
|
|
|
|
|
|
|
|
@table @option
|
2010-02-21 18:33:24 +00:00
|
|
|
|
|
|
|
@item -f @var{format}
|
|
|
|
Force format to use.
|
|
|
|
|
2010-02-21 11:43:01 +00:00
|
|
|
@item -unit
|
|
|
|
Show the unit of the displayed values.
|
|
|
|
|
|
|
|
@item -prefix
|
2010-09-07 09:10:56 +00:00
|
|
|
Use SI prefixes for the displayed values.
|
|
|
|
Unless the "-byte_binary_prefix" option is used all the prefixes
|
2010-02-21 11:43:01 +00:00
|
|
|
are decimal.
|
|
|
|
|
|
|
|
@item -byte_binary_prefix
|
|
|
|
Force the use of binary prefixes for byte values.
|
|
|
|
|
|
|
|
@item -sexagesimal
|
|
|
|
Use sexagesimal format HH:MM:SS.MICROSECONDS for time values.
|
|
|
|
|
|
|
|
@item -pretty
|
|
|
|
Prettify the format of the displayed values, it corresponds to the
|
2010-09-07 09:10:50 +00:00
|
|
|
options "-unit -prefix -byte_binary_prefix -sexagesimal".
|
2010-02-21 11:43:01 +00:00
|
|
|
|
2011-10-02 11:26:07 +02:00
|
|
|
@item -print_format @var{writer_name}[=@var{writer_options}]
|
2011-09-13 22:37:54 +02:00
|
|
|
Set the output printing format.
|
2011-10-02 11:59:38 +02:00
|
|
|
|
2011-10-02 11:26:07 +02:00
|
|
|
@var{writer_name} specifies the name of the writer, and
|
|
|
|
@var{writer_options} specifies the options to be passed to the writer.
|
|
|
|
|
2011-10-02 11:59:38 +02:00
|
|
|
For example for printing the output in JSON format, specify:
|
|
|
|
@example
|
|
|
|
-print_format json
|
|
|
|
@end example
|
|
|
|
|
|
|
|
For more details on the available output printing formats, see the
|
|
|
|
Writers section below.
|
2011-09-13 22:37:54 +02:00
|
|
|
|
2011-12-29 13:24:59 +01:00
|
|
|
@item -show_error
|
|
|
|
Show information about the error found when trying to probe the input.
|
|
|
|
|
|
|
|
The error information is printed within a section with name "ERROR".
|
|
|
|
|
2010-02-21 11:43:01 +00:00
|
|
|
@item -show_format
|
|
|
|
Show information about the container format of the input multimedia
|
|
|
|
stream.
|
|
|
|
|
|
|
|
All the container format information is printed within a section with
|
2010-09-07 09:10:50 +00:00
|
|
|
name "FORMAT".
|
2010-02-21 11:43:01 +00:00
|
|
|
|
2010-07-28 23:17:59 +00:00
|
|
|
@item -show_packets
|
|
|
|
Show information about each packet contained in the input multimedia
|
|
|
|
stream.
|
|
|
|
|
|
|
|
The information for each single packet is printed within a dedicated
|
2010-09-07 09:10:50 +00:00
|
|
|
section with name "PACKET".
|
2010-07-28 23:17:59 +00:00
|
|
|
|
2012-01-05 01:04:14 +01:00
|
|
|
@item -show_frames
|
2012-01-10 22:44:32 +01:00
|
|
|
Show information about each frame contained in the input multimedia
|
2012-01-05 01:04:14 +01:00
|
|
|
stream.
|
|
|
|
|
|
|
|
The information for each single frame is printed within a dedicated
|
|
|
|
section with name "FRAME".
|
|
|
|
|
2010-02-21 11:43:01 +00:00
|
|
|
@item -show_streams
|
|
|
|
Show information about each media stream contained in the input
|
|
|
|
multimedia stream.
|
|
|
|
|
|
|
|
Each media stream information is printed within a dedicated section
|
2010-09-07 09:10:50 +00:00
|
|
|
with name "STREAM".
|
2010-02-21 11:43:01 +00:00
|
|
|
|
2012-02-01 16:23:53 +01:00
|
|
|
@item -count_frames
|
|
|
|
Count the number of frames per stream and report it in the
|
|
|
|
corresponding stream section.
|
|
|
|
|
|
|
|
@item -count_packets
|
|
|
|
Count the number of packets per stream and report it in the
|
|
|
|
corresponding stream section.
|
|
|
|
|
2011-12-22 10:34:31 +01:00
|
|
|
@item -show_private_data, -private
|
|
|
|
Show private data, that is data depending on the format of the
|
|
|
|
particular shown element.
|
|
|
|
This option is enabled by default, but you may need to disable it
|
|
|
|
for specific uses, for example when creating XSD-compliant XML output.
|
|
|
|
|
2012-01-01 17:19:58 +01:00
|
|
|
@item -show_program_version
|
|
|
|
Show information related to program version.
|
|
|
|
|
|
|
|
Version information is printed within a section with name
|
|
|
|
"PROGRAM_VERSION".
|
|
|
|
|
|
|
|
@item -show_library_versions
|
|
|
|
Show information related to library versions.
|
|
|
|
|
|
|
|
Version information for each library is printed within a section with
|
|
|
|
name "LIBRARY_VERSION".
|
|
|
|
|
|
|
|
@item -show_versions
|
|
|
|
Show information related to program and library versions. This is the
|
|
|
|
equivalent of setting both @option{-show_program_version} and
|
|
|
|
@option{-show_library_versions} options.
|
|
|
|
|
2011-06-05 00:09:04 +02:00
|
|
|
@item -i @var{input_file}
|
|
|
|
Read @var{input_file}.
|
|
|
|
|
2010-02-21 11:43:01 +00:00
|
|
|
@end table
|
|
|
|
@c man end
|
|
|
|
|
2011-10-02 11:59:38 +02:00
|
|
|
@chapter Writers
|
|
|
|
@c man begin WRITERS
|
|
|
|
|
2012-01-02 15:32:55 +01:00
|
|
|
A writer defines the output format adopted by @command{ffprobe}, and will be
|
2011-10-02 11:59:38 +02:00
|
|
|
used for printing all the parts of the output.
|
|
|
|
|
|
|
|
A writer may accept one or more arguments, which specify the options to
|
|
|
|
adopt.
|
|
|
|
|
|
|
|
A description of the currently available writers follows.
|
|
|
|
|
|
|
|
@section default
|
|
|
|
Default format.
|
|
|
|
|
|
|
|
Print each section in the form:
|
|
|
|
@example
|
|
|
|
[SECTION]
|
|
|
|
key1=val1
|
|
|
|
...
|
|
|
|
keyN=valN
|
|
|
|
[/SECTION]
|
|
|
|
@end example
|
|
|
|
|
|
|
|
Metadata tags are printed as a line in the corresponding FORMAT or
|
|
|
|
STREAM section, and are prefixed by the string "TAG:".
|
|
|
|
|
2011-10-02 11:25:44 +02:00
|
|
|
@section compact
|
|
|
|
Compact format.
|
|
|
|
|
|
|
|
Each section is printed on a single line.
|
|
|
|
If no option is specifid, the output has the form:
|
|
|
|
@example
|
|
|
|
section|key1=val1| ... |keyN=valN
|
|
|
|
@end example
|
|
|
|
|
|
|
|
Metadata tags are printed in the corresponding "format" or "stream"
|
|
|
|
section. A metadata tag key, if printed, is prefixed by the string
|
|
|
|
"tag:".
|
|
|
|
|
|
|
|
This writer accepts options as a list of @var{key}=@var{value} pairs,
|
|
|
|
separated by ":".
|
|
|
|
|
|
|
|
The description of the accepted options follows.
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
|
|
|
|
@item item_sep, s
|
|
|
|
Specify the character to use for separating fields in the output line.
|
|
|
|
It must be a single printable character, it is "|" by default.
|
|
|
|
|
|
|
|
@item nokey, nk
|
|
|
|
If set to 1 specify not to print the key of each field. Its default
|
|
|
|
value is 0.
|
|
|
|
|
|
|
|
@item escape, e
|
|
|
|
Set the escape mode to use, default to "c".
|
|
|
|
|
|
|
|
It can assume one of the following values:
|
|
|
|
@table @option
|
|
|
|
@item c
|
|
|
|
Perform C-like escaping. Strings containing a newline ('\n') or
|
|
|
|
carriage return ('\r'), the escaping character ('\') or the item
|
|
|
|
separator character @var{SEP} are escaped using C-like fashioned
|
|
|
|
escaping, so that a newline is converted to the sequence "\n", a
|
|
|
|
carriage return to "\r", '\' to "\\" and the separator @var{SEP} is
|
|
|
|
converted to "\@var{SEP}".
|
|
|
|
|
|
|
|
@item csv
|
|
|
|
Perform CSV-like escaping, as described in RFC4180. Strings
|
|
|
|
containing a newline ('\n'), a carriage return ('\r'), a double quote
|
|
|
|
('"'), or @var{SEP} are enclosed in double-quotes.
|
|
|
|
|
|
|
|
@item none
|
|
|
|
Perform no escaping.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@end table
|
|
|
|
|
2011-11-16 00:41:55 +01:00
|
|
|
@section csv
|
|
|
|
CSV format.
|
|
|
|
|
|
|
|
This writer is equivalent to
|
|
|
|
@code{compact=item_sep=,:nokey=1:escape=csv}.
|
|
|
|
|
2011-10-02 11:59:38 +02:00
|
|
|
@section json
|
|
|
|
JSON based format.
|
|
|
|
|
|
|
|
Each section is printed using JSON notation.
|
|
|
|
|
2012-01-09 14:36:52 +01:00
|
|
|
This writer accepts options as a list of @var{key}=@var{value} pairs,
|
|
|
|
separated by ":".
|
|
|
|
|
|
|
|
The description of the accepted options follows.
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
|
|
|
|
@item compact, c
|
|
|
|
If set to 1 enable compact output, that is each section will be
|
|
|
|
printed on a single line. Default value is 0.
|
|
|
|
@end table
|
|
|
|
|
2011-10-02 11:59:38 +02:00
|
|
|
For more information about JSON, see @url{http://www.json.org/}.
|
|
|
|
|
2011-10-09 00:24:31 +02:00
|
|
|
@section xml
|
|
|
|
XML based format.
|
|
|
|
|
|
|
|
The XML output is described in the XML schema description file
|
|
|
|
@file{ffprobe.xsd} installed in the FFmpeg datadir.
|
|
|
|
|
|
|
|
Note that the output issued will be compliant to the
|
|
|
|
@file{ffprobe.xsd} schema only when no special global output options
|
|
|
|
(@option{unit}, @option{prefix}, @option{byte_binary_prefix},
|
|
|
|
@option{sexagesimal} etc.) are specified.
|
|
|
|
|
|
|
|
This writer accepts options as a list of @var{key}=@var{value} pairs,
|
|
|
|
separated by ":".
|
|
|
|
|
|
|
|
The description of the accepted options follows.
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
|
|
|
|
@item fully_qualified, q
|
|
|
|
If set to 1 specify if the output should be fully qualified. Default
|
|
|
|
value is 0.
|
|
|
|
This is required for generating an XML file which can be validated
|
|
|
|
through an XSD file.
|
|
|
|
|
|
|
|
@item xsd_compliant, x
|
|
|
|
If set to 1 perform more checks for ensuring that the output is XSD
|
|
|
|
compliant. Default value is 0.
|
|
|
|
This option automatically sets @option{fully_qualified} to 1.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
For more information about the XML format, see
|
|
|
|
@url{http://www.w3.org/XML/}.
|
|
|
|
|
2012-01-03 10:47:42 +01:00
|
|
|
@chapter Timecode
|
|
|
|
|
|
|
|
@command{ffprobe} supports Timecode extraction:
|
|
|
|
|
|
|
|
@itemize
|
|
|
|
|
|
|
|
@item MPEG1/2 timecode is extracted from the GOP, and is available in the video
|
|
|
|
stream details (@option{-show_streams}, see @var{timecode}).
|
|
|
|
|
|
|
|
@item MOV timecode is extracted from tmcd track, so is available in the tmcd
|
2012-01-26 13:06:22 +01:00
|
|
|
stream metadata (@option{-show_streams}, see @var{TAG:timecode}).
|
2012-01-03 10:47:42 +01:00
|
|
|
|
|
|
|
@item DV and GXF timecodes are available in format metadata
|
|
|
|
(@option{-show_format}, see @var{TAG:timecode}).
|
|
|
|
|
|
|
|
@end itemize
|
|
|
|
|
2011-10-02 11:59:38 +02:00
|
|
|
@c man end WRITERS
|
|
|
|
|
2011-05-19 20:34:56 +02:00
|
|
|
@include decoders.texi
|
2011-01-09 10:22:21 +00:00
|
|
|
@include demuxers.texi
|
2010-07-31 15:45:29 +00:00
|
|
|
@include protocols.texi
|
2010-07-27 13:10:59 +00:00
|
|
|
@include indevs.texi
|
|
|
|
|
2010-02-21 11:43:01 +00:00
|
|
|
@ignore
|
|
|
|
|
|
|
|
@setfilename ffprobe
|
2011-04-23 15:19:17 +02:00
|
|
|
@settitle ffprobe media prober
|
2010-02-21 11:43:01 +00:00
|
|
|
|
|
|
|
@c man begin SEEALSO
|
2011-03-17 16:55:58 +01:00
|
|
|
ffmpeg(1), ffplay(1), ffserver(1) and the FFmpeg HTML documentation
|
2010-02-21 11:43:01 +00:00
|
|
|
@c man end
|
|
|
|
|
2010-06-05 16:21:17 +00:00
|
|
|
@c man begin AUTHORS
|
2011-03-17 16:55:58 +01:00
|
|
|
The FFmpeg developers
|
2010-06-05 16:21:17 +00:00
|
|
|
@c man end
|
|
|
|
|
2010-02-21 11:43:01 +00:00
|
|
|
@end ignore
|
|
|
|
|
|
|
|
@bye
|