2010-02-21 13:43:01 +02:00
|
|
|
\input texinfo @c -*- texinfo -*-
|
2015-02-09 17:17:44 +02:00
|
|
|
@documentencoding UTF-8
|
2010-02-21 13:43:01 +02:00
|
|
|
|
2011-04-23 16:19:17 +03:00
|
|
|
@settitle ffprobe Documentation
|
2010-02-21 13:43:01 +02:00
|
|
|
@titlepage
|
2011-04-23 16:19:17 +03:00
|
|
|
@center @titlefont{ffprobe Documentation}
|
2010-02-21 13:43:01 +02:00
|
|
|
@end titlepage
|
|
|
|
|
2011-01-29 14:24:13 +02:00
|
|
|
@top
|
|
|
|
|
|
|
|
@contents
|
|
|
|
|
2010-06-09 01:32:29 +03:00
|
|
|
@chapter Synopsis
|
|
|
|
|
2022-04-20 23:43:46 +02:00
|
|
|
ffprobe [@var{options}] @file{input_url}
|
2010-06-09 01:32:29 +03:00
|
|
|
|
2010-06-04 00:23:05 +03:00
|
|
|
@chapter Description
|
2010-02-21 13:43:01 +02:00
|
|
|
@c man begin DESCRIPTION
|
|
|
|
|
2011-04-23 17:40:01 +03:00
|
|
|
ffprobe gathers information from multimedia streams and prints it in
|
2010-02-21 13:43:01 +02: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.
|
|
|
|
|
2016-12-05 13:54:21 +02:00
|
|
|
If a url is specified in input, ffprobe will try to open and
|
|
|
|
probe the url content. If the url cannot be opened or recognized as
|
2010-02-21 13:43:01 +02:00
|
|
|
a multimedia file, a positive exit code is returned.
|
|
|
|
|
2021-04-18 23:11:01 +02:00
|
|
|
If no output is specified as output with @option{o} ffprobe will write
|
|
|
|
to stdout.
|
|
|
|
|
2011-04-23 17:40:01 +03:00
|
|
|
ffprobe may be employed both as a standalone application or in
|
2010-02-21 13:43:01 +02: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 17:40:01 +03:00
|
|
|
ffprobe output is designed to be easily parsable by a textual filter,
|
2011-10-02 12:59:38 +03:00
|
|
|
and consists of one or more sections of a form defined by the selected
|
2023-10-15 11:25:23 +02:00
|
|
|
writer, which is specified by the @option{output_format} option.
|
2010-02-21 13:43:01 +02:00
|
|
|
|
2012-11-20 02:08:48 +03:00
|
|
|
Sections may contain other nested sections, and are identified by a
|
|
|
|
name (which may be shared by other sections), and an unique
|
|
|
|
name. See the output of @option{sections}.
|
|
|
|
|
2010-02-21 13:43:01 +02:00
|
|
|
Metadata tags stored in the container or in the streams are recognized
|
2024-03-02 21:03:20 +02:00
|
|
|
and printed in the corresponding "FORMAT", "STREAM", "STREAM_GROUP_STREAM"
|
|
|
|
or "PROGRAM_STREAM" section.
|
2010-02-21 13:43:01 +02:00
|
|
|
|
|
|
|
@c man end
|
|
|
|
|
2010-06-09 01:32:29 +03:00
|
|
|
@chapter Options
|
2010-02-21 13:43:01 +02:00
|
|
|
@c man begin OPTIONS
|
|
|
|
|
2013-09-09 01:36:55 +03:00
|
|
|
@include fftools-common-opts.texi
|
2010-02-21 13:43:01 +02:00
|
|
|
|
|
|
|
@section Main options
|
|
|
|
|
|
|
|
@table @option
|
2010-02-21 20:33:24 +02:00
|
|
|
|
|
|
|
@item -f @var{format}
|
|
|
|
Force format to use.
|
|
|
|
|
2010-02-21 13:43:01 +02:00
|
|
|
@item -unit
|
|
|
|
Show the unit of the displayed values.
|
|
|
|
|
|
|
|
@item -prefix
|
2010-09-07 12:10:56 +03:00
|
|
|
Use SI prefixes for the displayed values.
|
|
|
|
Unless the "-byte_binary_prefix" option is used all the prefixes
|
2010-02-21 13:43:01 +02: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 12:10:50 +03:00
|
|
|
options "-unit -prefix -byte_binary_prefix -sexagesimal".
|
2010-02-21 13:43:01 +02:00
|
|
|
|
2023-10-15 11:25:23 +02:00
|
|
|
@item -output_format, -of, -print_format @var{writer_name}[=@var{writer_options}]
|
2011-09-13 23:37:54 +03:00
|
|
|
Set the output printing format.
|
2011-10-02 12:59:38 +03:00
|
|
|
|
2011-10-02 12:26:07 +03: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 12:59:38 +03:00
|
|
|
For example for printing the output in JSON format, specify:
|
|
|
|
@example
|
2023-10-15 11:25:23 +02:00
|
|
|
-output_format json
|
2011-10-02 12:59:38 +03:00
|
|
|
@end example
|
|
|
|
|
|
|
|
For more details on the available output printing formats, see the
|
|
|
|
Writers section below.
|
2011-09-13 23:37:54 +03:00
|
|
|
|
2012-11-20 02:08:48 +03:00
|
|
|
@item -sections
|
|
|
|
Print sections structure and section information, and exit. The output
|
|
|
|
is not meant to be parsed by a machine.
|
|
|
|
|
2012-10-04 18:38:43 +03:00
|
|
|
@item -select_streams @var{stream_specifier}
|
|
|
|
Select only the streams specified by @var{stream_specifier}. This
|
|
|
|
option affects only the options related to streams
|
|
|
|
(e.g. @code{show_streams}, @code{show_packets}, etc.).
|
|
|
|
|
|
|
|
For example to show only audio streams, you can use the command:
|
|
|
|
@example
|
|
|
|
ffprobe -show_streams -select_streams a INPUT
|
|
|
|
@end example
|
|
|
|
|
|
|
|
To show only video packets belonging to the video stream with index 1:
|
|
|
|
@example
|
|
|
|
ffprobe -show_packets -select_streams v:1 INPUT
|
|
|
|
@end example
|
|
|
|
|
2012-04-07 20:18:09 +03:00
|
|
|
@item -show_data
|
2013-08-11 22:21:53 +03:00
|
|
|
Show payload data, as a hexadecimal and ASCII dump. Coupled with
|
2012-04-07 20:18:09 +03:00
|
|
|
@option{-show_packets}, it will dump the packets' data. Coupled with
|
|
|
|
@option{-show_streams}, it will dump the codec extradata.
|
|
|
|
|
|
|
|
The dump is printed as the "data" field. It may contain newlines.
|
|
|
|
|
2014-04-21 18:49:33 +03:00
|
|
|
@item -show_data_hash @var{algorithm}
|
|
|
|
Show a hash of payload data, for packets with @option{-show_packets} and for
|
|
|
|
codec extradata with @option{-show_streams}.
|
|
|
|
|
2011-12-29 15:24:59 +03: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 13:43:01 +02: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 12:10:50 +03:00
|
|
|
name "FORMAT".
|
2010-02-21 13:43:01 +02:00
|
|
|
|
2012-05-07 23:42:41 +03:00
|
|
|
@item -show_format_entry @var{name}
|
|
|
|
Like @option{-show_format}, but only prints the specified entry of the
|
|
|
|
container format information, rather than all. This option may be given more
|
|
|
|
than once, then all specified entries will be shown.
|
|
|
|
|
2012-09-17 22:08:09 +03:00
|
|
|
This option is deprecated, use @code{show_entries} instead.
|
|
|
|
|
|
|
|
@item -show_entries @var{section_entries}
|
|
|
|
Set list of entries to show.
|
|
|
|
|
|
|
|
Entries are specified according to the following
|
|
|
|
syntax. @var{section_entries} contains a list of section entries
|
|
|
|
separated by @code{:}. Each section entry is composed by a section
|
|
|
|
name (or unique name), optionally followed by a list of entries local
|
|
|
|
to that section, separated by @code{,}.
|
|
|
|
|
|
|
|
If section name is specified but is followed by no @code{=}, all
|
|
|
|
entries are printed to output, together with all the contained
|
|
|
|
sections. Otherwise only the entries specified in the local section
|
|
|
|
entries list are printed. In particular, if @code{=} is specified but
|
|
|
|
the list of local entries is empty, then no entries will be shown for
|
|
|
|
that section.
|
|
|
|
|
|
|
|
Note that the order of specification of the local section entries is
|
|
|
|
not honored in the output, and the usual display order will be
|
|
|
|
retained.
|
|
|
|
|
|
|
|
The formal syntax is given by:
|
|
|
|
@example
|
|
|
|
@var{LOCAL_SECTION_ENTRIES} ::= @var{SECTION_ENTRY_NAME}[,@var{LOCAL_SECTION_ENTRIES}]
|
|
|
|
@var{SECTION_ENTRY} ::= @var{SECTION_NAME}[=[@var{LOCAL_SECTION_ENTRIES}]]
|
|
|
|
@var{SECTION_ENTRIES} ::= @var{SECTION_ENTRY}[:@var{SECTION_ENTRIES}]
|
|
|
|
@end example
|
|
|
|
|
|
|
|
For example, to show only the index and type of each stream, and the PTS
|
|
|
|
time, duration time, and stream index of the packets, you can specify
|
|
|
|
the argument:
|
|
|
|
@example
|
|
|
|
packet=pts_time,duration_time,stream_index : stream=index,codec_type
|
|
|
|
@end example
|
|
|
|
|
|
|
|
To show all the entries in the section "format", but only the codec
|
|
|
|
type in the section "stream", specify the argument:
|
|
|
|
@example
|
|
|
|
format : stream=codec_type
|
|
|
|
@end example
|
|
|
|
|
|
|
|
To show all the tags in the stream and format sections:
|
|
|
|
@example
|
2014-08-28 13:19:33 +03:00
|
|
|
stream_tags : format_tags
|
2012-09-17 22:08:09 +03:00
|
|
|
@end example
|
|
|
|
|
|
|
|
To show only the @code{title} tag (if available) in the stream
|
|
|
|
sections:
|
|
|
|
@example
|
|
|
|
stream_tags=title
|
|
|
|
@end example
|
|
|
|
|
2010-07-29 02:17:59 +03: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 12:10:50 +03:00
|
|
|
section with name "PACKET".
|
2010-07-29 02:17:59 +03:00
|
|
|
|
2012-01-05 03:04:14 +03:00
|
|
|
@item -show_frames
|
2013-11-24 17:09:52 +03:00
|
|
|
Show information about each frame and subtitle contained in the input
|
|
|
|
multimedia stream.
|
2012-01-05 03:04:14 +03:00
|
|
|
|
|
|
|
The information for each single frame is printed within a dedicated
|
2013-11-24 17:09:52 +03:00
|
|
|
section with name "FRAME" or "SUBTITLE".
|
2012-01-05 03:04:14 +03:00
|
|
|
|
2017-03-14 19:11:14 +02:00
|
|
|
@item -show_log @var{loglevel}
|
|
|
|
Show logging information from the decoder about each frame according to
|
|
|
|
the value set in @var{loglevel}, (see @code{-loglevel}). This option requires @code{-show_frames}.
|
|
|
|
|
|
|
|
The information for each log message is printed within a dedicated
|
|
|
|
section with name "LOG".
|
|
|
|
|
2010-02-21 13:43:01 +02: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 12:10:50 +03:00
|
|
|
with name "STREAM".
|
2010-02-21 13:43:01 +02:00
|
|
|
|
2013-07-25 13:55:40 +03:00
|
|
|
@item -show_programs
|
|
|
|
Show information about programs and their streams contained in the input
|
|
|
|
multimedia stream.
|
|
|
|
|
|
|
|
Each media stream information is printed within a dedicated section
|
|
|
|
with name "PROGRAM_STREAM".
|
|
|
|
|
2024-03-02 21:03:20 +02:00
|
|
|
@item -show_stream_groups
|
|
|
|
Show information about stream groups and their streams contained in the
|
|
|
|
input multimedia stream.
|
|
|
|
|
|
|
|
Each media stream information is printed within a dedicated section
|
|
|
|
with name "STREAM_GROUP_STREAM".
|
|
|
|
|
2013-06-06 10:54:58 +03:00
|
|
|
@item -show_chapters
|
|
|
|
Show information about chapters stored in the format.
|
|
|
|
|
|
|
|
Each chapter is printed within a dedicated section with name "CHAPTER".
|
|
|
|
|
2012-02-01 18:23:53 +03: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.
|
|
|
|
|
2012-10-22 17:01:29 +03:00
|
|
|
@item -read_intervals @var{read_intervals}
|
|
|
|
|
|
|
|
Read only the specified intervals. @var{read_intervals} must be a
|
|
|
|
sequence of interval specifications separated by ",".
|
|
|
|
@command{ffprobe} will seek to the interval starting point, and will
|
|
|
|
continue reading from that.
|
|
|
|
|
|
|
|
Each interval is specified by two optional parts, separated by "%".
|
|
|
|
|
|
|
|
The first part specifies the interval start position. It is
|
2016-10-13 23:08:01 +02:00
|
|
|
interpreted as an absolute position, or as a relative offset from the
|
2012-10-22 17:01:29 +03:00
|
|
|
current position if it is preceded by the "+" character. If this first
|
|
|
|
part is not specified, no seeking will be performed when reading this
|
|
|
|
interval.
|
|
|
|
|
|
|
|
The second part specifies the interval end position. It is interpreted
|
|
|
|
as an absolute position, or as a relative offset from the current
|
|
|
|
position if it is preceded by the "+" character. If the offset
|
|
|
|
specification starts with "#", it is interpreted as the number of
|
|
|
|
packets to read (not including the flushing packets) from the interval
|
|
|
|
start. If no second part is specified, the program will read until the
|
|
|
|
end of the input.
|
|
|
|
|
|
|
|
Note that seeking is not accurate, thus the actual interval start
|
|
|
|
point may be different from the specified position. Also, when an
|
|
|
|
interval duration is specified, the absolute end time will be computed
|
|
|
|
by adding the duration to the interval start point found by seeking
|
|
|
|
the file, rather than to the specified start value.
|
|
|
|
|
|
|
|
The formal syntax is given by:
|
|
|
|
@example
|
|
|
|
@var{INTERVAL} ::= [@var{START}|+@var{START_OFFSET}][%[@var{END}|+@var{END_OFFSET}]]
|
|
|
|
@var{INTERVALS} ::= @var{INTERVAL}[,@var{INTERVALS}]
|
|
|
|
@end example
|
|
|
|
|
|
|
|
A few examples follow.
|
|
|
|
@itemize
|
|
|
|
@item
|
|
|
|
Seek to time 10, read packets until 20 seconds after the found seek
|
|
|
|
point, then seek to position @code{01:30} (1 minute and thirty
|
|
|
|
seconds) and read packets until position @code{01:45}.
|
|
|
|
@example
|
|
|
|
10%+20,01:30%01:45
|
|
|
|
@end example
|
|
|
|
|
|
|
|
@item
|
|
|
|
Read only 42 packets after seeking to position @code{01:23}:
|
|
|
|
@example
|
|
|
|
01:23%+#42
|
|
|
|
@end example
|
|
|
|
|
|
|
|
@item
|
|
|
|
Read only the first 20 seconds from the start:
|
|
|
|
@example
|
|
|
|
%+20
|
|
|
|
@end example
|
|
|
|
|
|
|
|
@item
|
|
|
|
Read from the start until position @code{02:30}:
|
|
|
|
@example
|
|
|
|
%02:30
|
|
|
|
@end example
|
|
|
|
@end itemize
|
|
|
|
|
2011-12-22 12:34:31 +03: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 19:19:58 +03: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.
|
|
|
|
|
2014-09-11 10:16:52 +03:00
|
|
|
@item -show_pixel_formats
|
|
|
|
Show information about all pixel formats supported by FFmpeg.
|
|
|
|
|
|
|
|
Pixel format information for each format is printed within a section
|
|
|
|
with name "PIXEL_FORMAT".
|
|
|
|
|
2021-05-01 14:07:34 +02:00
|
|
|
@item -show_optional_fields @var{value}
|
|
|
|
Some writers viz. JSON and XML, omit the printing of fields with invalid or non-applicable values,
|
|
|
|
while other writers always print them. This option enables one to control this behaviour.
|
|
|
|
Valid values are @code{always}/@code{1}, @code{never}/@code{0} and @code{auto}/@code{-1}.
|
|
|
|
Default is @var{auto}.
|
|
|
|
|
2024-12-09 01:27:39 +02:00
|
|
|
@item -analyze_frames
|
|
|
|
Analyze frames and/or their side data up to the provided read interval,
|
|
|
|
providing additional information that may be useful at a stream level.
|
|
|
|
Must be paired with the @option{-show_streams} option or it will have no effect.
|
|
|
|
|
|
|
|
Currently, the additional fields provided by this option when enabled are the
|
|
|
|
@code{closed_captions} and @code{film_grain} fields.
|
|
|
|
|
|
|
|
For example, to analyze the first 20 seconds and populate these fields:
|
|
|
|
@example
|
|
|
|
ffprobe -show_streams -analyze_frames -read_intervals "%+20" INPUT
|
|
|
|
@end example
|
|
|
|
|
2012-09-22 02:42:29 +03:00
|
|
|
@item -bitexact
|
|
|
|
Force bitexact output, useful to produce output which is not dependent
|
|
|
|
on the specific build.
|
|
|
|
|
2016-12-05 13:54:21 +02:00
|
|
|
@item -i @var{input_url}
|
|
|
|
Read @var{input_url}.
|
2011-06-05 01:09:04 +03:00
|
|
|
|
2021-04-18 23:11:01 +02:00
|
|
|
@item -o @var{output_url}
|
|
|
|
Write output to @var{output_url}. If not specified, the output is sent
|
|
|
|
to stdout.
|
|
|
|
|
2010-02-21 13:43:01 +02:00
|
|
|
@end table
|
|
|
|
@c man end
|
|
|
|
|
2011-10-02 12:59:38 +03:00
|
|
|
@chapter Writers
|
|
|
|
@c man begin WRITERS
|
|
|
|
|
2012-01-02 17:32:55 +03:00
|
|
|
A writer defines the output format adopted by @command{ffprobe}, and will be
|
2011-10-02 12:59:38 +03:00
|
|
|
used for printing all the parts of the output.
|
|
|
|
|
2012-11-16 12:25:16 +03:00
|
|
|
A writer may accept one or more arguments, which specify the options
|
|
|
|
to adopt. The options are specified as a list of @var{key}=@var{value}
|
|
|
|
pairs, separated by ":".
|
2011-10-02 12:59:38 +03:00
|
|
|
|
2013-10-02 17:22:17 +03:00
|
|
|
All writers support the following options:
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
@item string_validation, sv
|
|
|
|
Set string validation mode.
|
|
|
|
|
|
|
|
The following values are accepted.
|
|
|
|
@table @samp
|
|
|
|
@item fail
|
|
|
|
The writer will fail immediately in case an invalid string (UTF-8)
|
|
|
|
sequence or code point is found in the input. This is especially
|
|
|
|
useful to validate input metadata.
|
|
|
|
|
|
|
|
@item ignore
|
|
|
|
Any validation error will be ignored. This will result in possibly
|
|
|
|
broken output, especially with the json or xml writer.
|
|
|
|
|
|
|
|
@item replace
|
|
|
|
The writer will substitute invalid UTF-8 sequences or code points with
|
|
|
|
the string specified with the @option{string_validation_replacement}.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
Default value is @samp{replace}.
|
|
|
|
|
|
|
|
@item string_validation_replacement, svr
|
|
|
|
Set replacement string to use in case @option{string_validation} is
|
|
|
|
set to @samp{replace}.
|
|
|
|
|
|
|
|
In case the option is not specified, the writer will assume the empty
|
|
|
|
string, that is it will remove the invalid sequences from the input
|
|
|
|
strings.
|
|
|
|
@end table
|
|
|
|
|
2011-10-02 12:59:38 +03:00
|
|
|
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
|
|
|
|
|
2024-03-02 21:03:20 +02:00
|
|
|
Metadata tags are printed as a line in the corresponding FORMAT, STREAM,
|
|
|
|
STREAM_GROUP_STREAM or PROGRAM_STREAM section, and are prefixed by the
|
|
|
|
string "TAG:".
|
2011-10-02 12:59:38 +03:00
|
|
|
|
2012-05-09 02:20:21 +03:00
|
|
|
A description of the accepted options follows.
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
|
2012-05-10 02:28:07 +03:00
|
|
|
@item nokey, nk
|
|
|
|
If set to 1 specify not to print the key of each field. Default value
|
|
|
|
is 0.
|
|
|
|
|
2012-05-09 02:20:21 +03:00
|
|
|
@item noprint_wrappers, nw
|
|
|
|
If set to 1 specify not to print the section header and footer.
|
|
|
|
Default value is 0.
|
|
|
|
@end table
|
|
|
|
|
2012-09-19 12:23:11 +03:00
|
|
|
@section compact, csv
|
|
|
|
Compact and CSV format.
|
|
|
|
|
|
|
|
The @code{csv} writer is equivalent to @code{compact}, but supports
|
|
|
|
different defaults.
|
2011-10-02 12:25:44 +03:00
|
|
|
|
|
|
|
Each section is printed on a single line.
|
2019-02-09 20:07:46 +02:00
|
|
|
If no option is specified, the output has the form:
|
2011-10-02 12:25:44 +03:00
|
|
|
@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:".
|
|
|
|
|
|
|
|
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.
|
2012-09-19 12:23:11 +03:00
|
|
|
It must be a single printable character, it is "|" by default ("," for
|
|
|
|
the @code{csv} writer).
|
2011-10-02 12:25:44 +03:00
|
|
|
|
|
|
|
@item nokey, nk
|
|
|
|
If set to 1 specify not to print the key of each field. Its default
|
2012-09-19 12:23:11 +03:00
|
|
|
value is 0 (1 for the @code{csv} writer).
|
2011-10-02 12:25:44 +03:00
|
|
|
|
|
|
|
@item escape, e
|
2012-09-19 12:23:11 +03:00
|
|
|
Set the escape mode to use, default to "c" ("csv" for the @code{csv}
|
|
|
|
writer).
|
2011-10-02 12:25:44 +03:00
|
|
|
|
|
|
|
It can assume one of the following values:
|
|
|
|
@table @option
|
|
|
|
@item c
|
2015-03-23 05:47:18 +02:00
|
|
|
Perform C-like escaping. Strings containing a newline (@samp{\n}), carriage
|
|
|
|
return (@samp{\r}), a tab (@samp{\t}), a form feed (@samp{\f}), the escaping
|
|
|
|
character (@samp{\}) or the item separator character @var{SEP} are escaped
|
|
|
|
using C-like fashioned escaping, so that a newline is converted to the
|
|
|
|
sequence @samp{\n}, a carriage return to @samp{\r}, @samp{\} to @samp{\\} and
|
|
|
|
the separator @var{SEP} is converted to @samp{\@var{SEP}}.
|
2011-10-02 12:25:44 +03:00
|
|
|
|
|
|
|
@item csv
|
|
|
|
Perform CSV-like escaping, as described in RFC4180. Strings
|
2015-03-23 05:47:18 +02:00
|
|
|
containing a newline (@samp{\n}), a carriage return (@samp{\r}), a double quote
|
|
|
|
(@samp{"}), or @var{SEP} are enclosed in double-quotes.
|
2011-10-02 12:25:44 +03:00
|
|
|
|
|
|
|
@item none
|
|
|
|
Perform no escaping.
|
|
|
|
@end table
|
|
|
|
|
2012-09-10 14:36:27 +03:00
|
|
|
@item print_section, p
|
2017-09-22 01:10:56 +02:00
|
|
|
Print the section name at the beginning of each line if the value is
|
2012-09-10 14:36:27 +03:00
|
|
|
@code{1}, disable it with value set to @code{0}. Default value is
|
|
|
|
@code{1}.
|
|
|
|
|
2011-10-02 12:25:44 +03:00
|
|
|
@end table
|
|
|
|
|
2012-05-30 00:22:39 +03:00
|
|
|
@section flat
|
|
|
|
Flat format.
|
|
|
|
|
|
|
|
A free-form output where each line contains an explicit key=value, such as
|
|
|
|
"streams.stream.3.tags.foo=bar". The output is shell escaped, so it can be
|
|
|
|
directly embedded in sh scripts as long as the separator character is an
|
|
|
|
alphanumeric character or an underscore (see @var{sep_char} option).
|
|
|
|
|
|
|
|
The description of the accepted options follows.
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
@item sep_char, s
|
|
|
|
Separator character used to separate the chapter, the section name, IDs and
|
|
|
|
potential tags in the printed field key.
|
|
|
|
|
2015-03-23 05:47:18 +02:00
|
|
|
Default value is @samp{.}.
|
2012-05-30 00:22:39 +03:00
|
|
|
|
|
|
|
@item hierarchical, h
|
|
|
|
Specify if the section name specification should be hierarchical. If
|
|
|
|
set to 1, and if there is more than one section in the current
|
|
|
|
chapter, the section name will be prefixed by the name of the
|
|
|
|
chapter. A value of 0 will disable this behavior.
|
|
|
|
|
|
|
|
Default value is 1.
|
|
|
|
@end table
|
|
|
|
|
2012-05-27 02:24:19 +03:00
|
|
|
@section ini
|
|
|
|
INI format output.
|
|
|
|
|
|
|
|
Print output in an INI based format.
|
|
|
|
|
|
|
|
The following conventions are adopted:
|
|
|
|
|
|
|
|
@itemize
|
|
|
|
@item
|
|
|
|
all key and values are UTF-8
|
|
|
|
@item
|
2015-03-23 05:47:18 +02:00
|
|
|
@samp{.} is the subgroup separator
|
2012-05-27 02:24:19 +03:00
|
|
|
@item
|
2015-03-23 05:47:18 +02:00
|
|
|
newline, @samp{\t}, @samp{\f}, @samp{\b} and the following characters are
|
|
|
|
escaped
|
2012-05-27 02:24:19 +03:00
|
|
|
@item
|
2015-03-23 05:47:18 +02:00
|
|
|
@samp{\} is the escape character
|
2012-05-27 02:24:19 +03:00
|
|
|
@item
|
2015-03-23 05:47:18 +02:00
|
|
|
@samp{#} is the comment indicator
|
2012-05-27 02:24:19 +03:00
|
|
|
@item
|
2015-03-23 05:47:18 +02:00
|
|
|
@samp{=} is the key/value separator
|
2012-05-27 02:24:19 +03:00
|
|
|
@item
|
2015-03-23 05:47:18 +02:00
|
|
|
@samp{:} is not used but usually parsed as key/value separator
|
2012-05-27 02:24:19 +03:00
|
|
|
@end itemize
|
|
|
|
|
|
|
|
This writer accepts options as a list of @var{key}=@var{value} pairs,
|
2015-03-23 05:47:18 +02:00
|
|
|
separated by @samp{:}.
|
2012-05-27 02:24:19 +03:00
|
|
|
|
|
|
|
The description of the accepted options follows.
|
|
|
|
|
|
|
|
@table @option
|
|
|
|
@item hierarchical, h
|
|
|
|
Specify if the section name specification should be hierarchical. If
|
|
|
|
set to 1, and if there is more than one section in the current
|
|
|
|
chapter, the section name will be prefixed by the name of the
|
|
|
|
chapter. A value of 0 will disable this behavior.
|
|
|
|
|
|
|
|
Default value is 1.
|
|
|
|
@end table
|
|
|
|
|
2011-10-02 12:59:38 +03:00
|
|
|
@section json
|
|
|
|
JSON based format.
|
|
|
|
|
|
|
|
Each section is printed using JSON notation.
|
|
|
|
|
2012-01-09 16:36:52 +03:00
|
|
|
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 12:59:38 +03:00
|
|
|
For more information about JSON, see @url{http://www.json.org/}.
|
|
|
|
|
2011-10-09 01:24:31 +03: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.
|
|
|
|
|
2012-05-20 16:16:20 +03:00
|
|
|
An updated version of the schema can be retrieved at the url
|
|
|
|
@url{http://www.ffmpeg.org/schema/ffprobe.xsd}, which redirects to the
|
|
|
|
latest schema committed into the FFmpeg development source code tree.
|
|
|
|
|
2011-10-09 01:24:31 +03:00
|
|
|
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.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
2018-05-12 21:09:18 +02:00
|
|
|
@item xsd_strict, x
|
2011-10-09 01:24:31 +03:00
|
|
|
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
|
2019-02-09 20:07:46 +02:00
|
|
|
@url{https://www.w3.org/XML/}.
|
2012-05-12 23:42:06 +03:00
|
|
|
@c man end WRITERS
|
2011-10-09 01:24:31 +03:00
|
|
|
|
2012-01-03 12:47:42 +03:00
|
|
|
@chapter Timecode
|
2012-05-12 23:42:06 +03:00
|
|
|
@c man begin TIMECODE
|
2012-01-03 12:47:42 +03:00
|
|
|
|
|
|
|
@command{ffprobe} supports Timecode extraction:
|
|
|
|
|
|
|
|
@itemize
|
|
|
|
|
2012-05-12 23:42:06 +03:00
|
|
|
@item
|
|
|
|
MPEG1/2 timecode is extracted from the GOP, and is available in the video
|
2012-01-03 12:47:42 +03:00
|
|
|
stream details (@option{-show_streams}, see @var{timecode}).
|
|
|
|
|
2012-05-12 23:42:06 +03:00
|
|
|
@item
|
|
|
|
MOV timecode is extracted from tmcd track, so is available in the tmcd
|
2012-01-26 15:06:22 +03:00
|
|
|
stream metadata (@option{-show_streams}, see @var{TAG:timecode}).
|
2012-01-03 12:47:42 +03:00
|
|
|
|
2012-05-12 23:42:06 +03:00
|
|
|
@item
|
2012-05-31 10:31:04 +03:00
|
|
|
DV, GXF and AVI timecodes are available in format metadata
|
2012-01-03 12:47:42 +03:00
|
|
|
(@option{-show_format}, see @var{TAG:timecode}).
|
|
|
|
|
|
|
|
@end itemize
|
2012-05-12 23:42:06 +03:00
|
|
|
@c man end TIMECODE
|
2011-10-02 12:59:38 +03:00
|
|
|
|
2013-04-24 19:39:49 +03:00
|
|
|
@include config.texi
|
2013-03-19 22:54:26 +03:00
|
|
|
@ifset config-all
|
2014-01-09 08:19:52 +03:00
|
|
|
@set config-readonly
|
2013-04-24 19:39:49 +03:00
|
|
|
@ifset config-avutil
|
|
|
|
@include utils.texi
|
|
|
|
@end ifset
|
|
|
|
@ifset config-avcodec
|
|
|
|
@include codecs.texi
|
|
|
|
@include bitstream_filters.texi
|
|
|
|
@end ifset
|
|
|
|
@ifset config-avformat
|
|
|
|
@include formats.texi
|
|
|
|
@include protocols.texi
|
|
|
|
@end ifset
|
|
|
|
@ifset config-avdevice
|
|
|
|
@include devices.texi
|
|
|
|
@end ifset
|
|
|
|
@ifset config-swresample
|
|
|
|
@include resampler.texi
|
|
|
|
@end ifset
|
|
|
|
@ifset config-swscale
|
|
|
|
@include scaler.texi
|
|
|
|
@end ifset
|
|
|
|
@ifset config-avfilter
|
|
|
|
@include filters.texi
|
|
|
|
@end ifset
|
2020-08-22 12:41:15 +02:00
|
|
|
@include general_contents.texi
|
2013-03-19 22:54:26 +03:00
|
|
|
@end ifset
|
|
|
|
|
2012-12-16 22:53:16 +03:00
|
|
|
@chapter See Also
|
|
|
|
|
|
|
|
@ifhtml
|
2013-03-19 22:54:26 +03:00
|
|
|
@ifset config-all
|
|
|
|
@url{ffprobe.html,ffprobe},
|
|
|
|
@end ifset
|
|
|
|
@ifset config-not-all
|
|
|
|
@url{ffprobe-all.html,ffprobe-all},
|
|
|
|
@end ifset
|
2017-10-21 20:31:44 +02:00
|
|
|
@url{ffmpeg.html,ffmpeg}, @url{ffplay.html,ffplay},
|
2012-12-16 22:53:16 +03:00
|
|
|
@url{ffmpeg-utils.html,ffmpeg-utils},
|
|
|
|
@url{ffmpeg-scaler.html,ffmpeg-scaler},
|
|
|
|
@url{ffmpeg-resampler.html,ffmpeg-resampler},
|
|
|
|
@url{ffmpeg-codecs.html,ffmpeg-codecs},
|
2013-02-15 15:31:09 +03:00
|
|
|
@url{ffmpeg-bitstream-filters.html,ffmpeg-bitstream-filters},
|
2012-12-16 22:53:16 +03:00
|
|
|
@url{ffmpeg-formats.html,ffmpeg-formats},
|
|
|
|
@url{ffmpeg-devices.html,ffmpeg-devices},
|
|
|
|
@url{ffmpeg-protocols.html,ffmpeg-protocols},
|
|
|
|
@url{ffmpeg-filters.html,ffmpeg-filters}
|
|
|
|
@end ifhtml
|
|
|
|
|
|
|
|
@ifnothtml
|
2013-03-19 22:54:26 +03:00
|
|
|
@ifset config-all
|
|
|
|
ffprobe(1),
|
|
|
|
@end ifset
|
|
|
|
@ifset config-not-all
|
|
|
|
ffprobe-all(1),
|
|
|
|
@end ifset
|
2017-10-21 20:31:44 +02:00
|
|
|
ffmpeg(1), ffplay(1),
|
2012-12-16 22:53:16 +03:00
|
|
|
ffmpeg-utils(1), ffmpeg-scaler(1), ffmpeg-resampler(1),
|
|
|
|
ffmpeg-codecs(1), ffmpeg-bitstream-filters(1), ffmpeg-formats(1),
|
|
|
|
ffmpeg-devices(1), ffmpeg-protocols(1), ffmpeg-filters(1)
|
|
|
|
@end ifnothtml
|
|
|
|
|
2012-12-16 20:04:37 +03:00
|
|
|
@include authors.texi
|
|
|
|
|
2010-02-21 13:43:01 +02:00
|
|
|
@ignore
|
|
|
|
|
|
|
|
@setfilename ffprobe
|
2011-04-23 16:19:17 +03:00
|
|
|
@settitle ffprobe media prober
|
2010-02-21 13:43:01 +02:00
|
|
|
|
|
|
|
@end ignore
|
|
|
|
|
|
|
|
@bye
|