2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-04 15:45:21 +00:00
qpdf/manual/qpdf.1
2024-01-11 06:13:57 -05:00

1195 lines
43 KiB
Groff

.\"
.\" This file is automatically generated by generate_auto_job.
.\" Edits will be automatically overwritten if the build is
.\" run in maintainer mode.
.\"
.TH QPDF "1" "" "qpdf version 11.9.0" "User Commands"
.SH NAME
qpdf \- PDF transformation software
.SH SYNOPSIS
.B qpdf
.RI "[ " options " ] " infilename " [ " outfilename " ]"
.SH DESCRIPTION
The qpdf program is used to convert one PDF file to another equivalent
PDF file. It is capable of performing a variety of transformations
such as linearization (also known as web optimization or fast web
viewing), encryption, and decryption of PDF files. It also has many
options for inspecting or checking PDF files, some of which are
useful primarily to PDF developers.
.PP
For a summary of qpdf's options, please run \fBqpdf \-\-help\fR. A
complete manual can be found at https://qpdf.readthedocs.io.
.SH USAGE (basic invocation)
Read a PDF file, apply transformations or modifications, and write
a new PDF file.
Usage: qpdf [infile] [options] [outfile]
OR qpdf --help[={topic|--option}]
.IP \[bu]
infile, options, and outfile may be in any order as long as infile
precedes outfile.
.IP \[bu]
Use --empty in place of an input file for a zero-page, empty input
.IP \[bu]
Use --replace-input in place of an output file to overwrite the
input file with the output
.IP \[bu]
outfile may be - to write to stdout; reading from stdin is not supported
.IP \[bu]
@filename is an argument file; each line is treated as a separate
command-line argument
.IP \[bu]
@- may be used to read arguments from stdin
.IP \[bu]
Later options may override earlier options if contradictory
.PP
Related Options:
.TP
.B --empty \-\- use empty file as input
Use in place of infile for an empty input. Especially useful
with --pages.
.TP
.B --replace-input \-\- overwrite input with output
Use in place of outfile to overwrite the input file with the output.
.TP
.B --job-json-file \-\- job JSON file
--job-json-file=file
Specify the name of a file whose contents are expected to
contain a QPDFJob JSON file. Run qpdf --job-json-help for a
description of the JSON input file format.
.SH EXIT-STATUS (meanings of qpdf's exit codes)
Meaning of exit codes:
.IP \[bu]
0: no errors or warnings
.IP \[bu]
1: not used by qpdf but may be used by the shell if unable to invoke qpdf
.IP \[bu]
2: errors detected
.IP \[bu]
3: warnings detected, unless --warning-exit-0 is given
.PP
Related Options:
.TP
.B --warning-exit-0 \-\- exit 0 even with warnings
Use exit status 0 instead of 3 when warnings are present. When
combined with --no-warn, warnings are completely ignored.
.SH COMPLETION (shell completion)
Shell completion is supported with bash and zsh. Use
eval $(qpdf --completion-bash) or eval $(qpdf --completion-zsh)
to enable. The QPDF_EXECUTABLE environment variable overrides the
path to qpdf that these commands output.
.PP
Related Options:
.TP
.B --completion-bash \-\- enable bash completion
Output a command that enables bash completion
.TP
.B --completion-zsh \-\- enable zsh completion
Output a command that enables zsh completion
.SH HELP (information about qpdf)
Help options provide some information about qpdf itself. Help
options are only valid as the first and only command-line argument.
.PP
Related Options:
.TP
.B --help \-\- provide help
--help[=--option|topic]
--help: provide general information and a list of topics
--help=--option: provide help on a specific option
--help=topic: provide help on a topic
.TP
.B --version \-\- show qpdf version
Display the version of qpdf.
.TP
.B --copyright \-\- show copyright information
Display copyright and license information.
.TP
.B --show-crypto \-\- show available crypto providers
Show a list of available crypto providers, one per line. The
default provider is shown first.
.TP
.B --job-json-help \-\- show format of job JSON
Describe the format of the QPDFJob JSON input used by
--job-json-file.
.SH GENERAL (general options)
General options control qpdf's behavior in ways that are not
directly related to the operation it is performing.
.PP
Related Options:
.TP
.B --password \-\- password for encrypted file
--password=password
Specify a password for an encrypted, password-protected file.
Not needed for encrypted files without a password.
.TP
.B --password-file \-\- read password from a file
--password-file=filename
The first line of the specified file is used as the password.
This is used in place of the --password option.
.TP
.B --verbose \-\- print additional information
Output additional information about various things qpdf is
doing, including information about files created and operations
performed.
.TP
.B --progress \-\- show progress when writing
Indicate progress when writing files.
.TP
.B --no-warn \-\- suppress printing of warning messages
Suppress printing of warning messages. If warnings were
encountered, qpdf still exits with exit status 3.
Use --warning-exit-0 with --no-warn to completely ignore
warnings.
.TP
.B --deterministic-id \-\- generate ID deterministically
Generate a secure, random document ID only using static
information, such as the page contents. Does not use the file's
name or attributes or the current time.
.TP
.B --allow-weak-crypto \-\- allow insecure cryptographic algorithms
Allow creation of files with weak cryptographic algorithms. This
option is necessary to create 40-bit files or 128-bit files that
use RC4 encryption.
.TP
.B --keep-files-open \-\- manage keeping multiple files open
--keep-files-open=[y|n]
When qpdf needs to work with many files, as when merging large
numbers of files, explicitly indicate whether files should be
kept open. The default behavior is to determine this based on
the number of files.
.TP
.B --keep-files-open-threshold \-\- set threshold for --keep-files-open
--keep-files-open-threshold=count
Set the threshold used by --keep-files-open, overriding the
default value of 200.
.SH ADVANCED-CONTROL (tweak qpdf's behavior)
Advanced control options control qpdf's behavior in ways that would
normally never be needed by a user but that may be useful to
developers or people investigating problems with specific files.
.PP
Related Options:
.TP
.B --password-is-hex-key \-\- provide hex-encoded encryption key
Provide the underlying file encryption key as a hex-encoded
string rather than supplying a password. This is an expert
option.
.TP
.B --suppress-password-recovery \-\- don't try different password encodings
Suppress qpdf's usual behavior of attempting different encodings
of a password that contains non-ASCII Unicode characters if the
first attempt doesn't succeed.
.TP
.B --password-mode \-\- tweak how qpdf encodes passwords
--password-mode=mode
Fine-tune how qpdf controls encoding of Unicode passwords. Valid
options are auto, bytes, hex-bytes, and unicode.
.TP
.B --suppress-recovery \-\- suppress error recovery
Avoid attempting to recover when errors are found in a file's
cross reference table or stream lengths.
.TP
.B --ignore-xref-streams \-\- use xref tables rather than streams
Ignore any cross-reference streams in the file, falling back to
cross-reference tables or triggering document recovery.
.SH TRANSFORMATION (make structural PDF changes)
The options below tell qpdf to apply transformations that change
the structure without changing the content.
.PP
Related Options:
.TP
.B --linearize \-\- linearize (web-optimize) output
Create linearized (web-optimized) output files.
.TP
.B --encrypt \-\- start encryption options
--encrypt [options] --
Run qpdf --help=encryption for details.
.TP
.B --decrypt \-\- remove encryption from input file
Create an unencrypted output file even if the input file was
encrypted. Normally qpdf preserves whatever encryption was
present on the input file. This option overrides that behavior.
.TP
.B --remove-restrictions \-\- remove security restrictions from input file
Remove restrictions associated with digitally signed PDF files.
This may be combined with --decrypt to allow free editing of
previously signed/encrypted files. This option invalidates and
disables any digital signatures but leaves their visual
appearances intact.
.TP
.B --copy-encryption \-\- copy another file's encryption details
--copy-encryption=file
Copy encryption details from the specified file instead of
preserving the input file's encryption. Use --encryption-file-password
to specify the encryption file's password.
.TP
.B --encryption-file-password \-\- supply password for --copy-encryption
--encryption-file-password=password
If the file named in --copy-encryption requires a password, use
this option to supply the password.
.TP
.B --qdf \-\- enable viewing PDF code in a text editor
Create a PDF file suitable for viewing in a text editor and even
editing. This is for editing the PDF code, not the page contents.
All streams that can be uncompressed are uncompressed, and
content streams are normalized, among other changes. The
companion tool "fix-qdf" can be used to repair hand-edited QDF
files. QDF is a feature specific to the qpdf tool. Please see
the "QDF Mode" chapter in the manual.
.TP
.B --no-original-object-ids \-\- omit original object IDs in qdf
Omit comments in a QDF file indicating the object ID an object
had in the original file.
.TP
.B --compress-streams \-\- compress uncompressed streams
--compress-streams=[y|n]
Setting --compress-streams=n prevents qpdf from compressing
uncompressed streams. This can be useful if you are leaving some
streams uncompressed intentionally.
.TP
.B --decode-level \-\- control which streams to uncompress
--decode-level=parameter
When uncompressing streams, control which types of compression
schemes should be uncompressed:
.IP \[bu]
none: don't uncompress anything. This is the default with
--json-output.
.IP \[bu]
generalized: uncompress streams compressed with a
general-purpose compression algorithm. This is the default
except when --json-output is given.
.IP \[bu]
specialized: in addition to generalized, also uncompress
streams compressed with a special-purpose but non-lossy
compression scheme
.IP \[bu]
all: in addition to specialized, uncompress streams compressed
with lossy compression schemes like JPEG (DCT)
qpdf does not know how to uncompress all compression schemes.
.TP
.B --stream-data \-\- control stream compression
--stream-data=parameter
This option controls how streams are compressed in the output.
It is less granular than the newer options, --compress-streams
and --decode-level.
Parameters:
.IP \[bu]
compress: same as --compress-streams=y --decode-level=generalized
.IP \[bu]
preserve: same as --compress-streams=n --decode-level=none
.IP \[bu]
uncompress: same as --compress-streams=n --decode-level=generalized
.TP
.B --recompress-flate \-\- uncompress and recompress flate
The default generalized compression scheme used by PDF is flate,
which is the same as used by zip and gzip. Usually qpdf just
leaves these alone. This option tells qpdf to uncompress and
recompress streams compressed with flate. This can be useful
when combined with --compression-level.
.TP
.B --compression-level \-\- set compression level for flate
--compression-level=level
Set a compression level from 1 (least, fastest) to 9 (most,
slowest) when compressing files with flate (used in zip and
gzip), which is the default compression for most PDF files.
You need --recompress-flate with this option if you want to
change already compressed streams.
.TP
.B --normalize-content \-\- fix newlines in content streams
--normalize-content=[y|n]
Normalize newlines to UNIX-style newlines in PDF content
streams, which is useful for viewing them in a programmer's text
editor across multiple platforms. This is also turned on by
--qdf.
.TP
.B --object-streams \-\- control use of object streams
--object-streams=mode
Control what qpdf does regarding object streams. Options:
.IP \[bu]
preserve: preserve original object streams, if any (the default)
.IP \[bu]
disable: create output files with no object streams
.IP \[bu]
generate: create object streams, and compress objects when possible
.TP
.B --preserve-unreferenced \-\- preserve unreferenced objects
Preserve all objects from the input even if not referenced.
.TP
.B --remove-unreferenced-resources \-\- remove unreferenced page resources
--remove-unreferenced-resources=parameter
Remove from a page's resource dictionary any resources that are
not referenced in the page's contents. Parameters: "auto"
(default), "yes", "no".
.TP
.B --preserve-unreferenced-resources \-\- use --remove-unreferenced-resources=no
Synonym for --remove-unreferenced-resources=no. Use that instead.
.TP
.B --newline-before-endstream \-\- force a newline before endstream
For an extra newline before endstream. Using this option enables
qpdf to preserve PDF/A when rewriting such files.
.TP
.B --coalesce-contents \-\- combine content streams
If a page has an array of content streams, concatenate them into
a single content stream.
.TP
.B --externalize-inline-images \-\- convert inline to regular images
Convert inline images to regular images.
.TP
.B --ii-min-bytes \-\- set minimum size for --externalize-inline-images
--ii-min-bytes=size-in-bytes
Don't externalize inline images smaller than this size. The
default is 1,024. Use 0 for no minimum.
.TP
.B --min-version \-\- set minimum PDF version
--min-version=version
Force the PDF version of the output to be at least the specified
version. The version number format is
"major.minor[.extension-level]", which sets the version header
to "major.minor" and the extension level, if specified, to
"extension-level".
.TP
.B --force-version \-\- set output PDF version
--force-version=version
Force the output PDF file's PDF version header to be the specified
value, even if the file uses features that may not be available
in that version.
.SH PAGE-RANGES (page range syntax)
A full description of the page range syntax, with examples, can be
found in the manual. In summary, a range is a comma-separated list
of groups. A group is a number or a range of numbers separated by a
dash. A group may be prepended by x to exclude its members from the
previous group. A number may be one of
.IP \[bu]
<n> where <n> represents a number is the <n>th page
.IP \[bu]
r<n> is the <n>th page from the end
.IP \[bu]
z the last page, same as r1
.IP \[bu]
a,b,c pages a, b, and c
.IP \[bu]
a-b pages a through b inclusive; if a > b, this counts down
.IP \[bu]
a-b,xc pages a through b except page c
.IP \[bu]
a-b,xc-d pages a through b except pages c through d
You can append :even or :odd to select every other page from the
resulting set of pages, where :odd starts with the first page and
:even starts with the second page. These are odd and even pages
from the resulting set, not based on the original page numbers.
.SH MODIFICATION (change parts of the PDF)
Modification options make systematic changes to certain parts of
the PDF, causing the PDF to render differently from the original.
.PP
Related Options:
.TP
.B --pages \-\- begin page selection
--pages [--file=]file [options] [...] --
Run qpdf --help=page-selection for details.
.TP
.B --file \-\- source for pages
--file=file
Specify the file for the current page operation. This is used
with --pages, --overlay, and --underlay and appears between the
option and the terminating --. Run qpdf --help=page-selection
for details.
.TP
.B --range \-\- page range
--range=numeric-range
Specify the page range for the current page operation with
--pages. If omitted, all pages are selected. This is used
with --pages and appears between --pages and --. Run
qpdf --help=page-selection for details.
.TP
.B --collate \-\- collate with --pages
--collate[=n[,m,...]]
Collate rather than concatenate pages specified with --pages.
With a numeric parameter, collate in groups of n. The default
is 1. With comma-separated numeric parameters, take n from the
first file, m from the second, etc. Run
qpdf --help=page-selection for additional details.
.TP
.B --split-pages \-\- write pages to separate files
--split-pages[=n]
This option causes qpdf to create separate output files for each
page or group of pages rather than a single output file.
File names are generated from the specified output file as follows:
.IP \[bu]
If the string %d appears in the output file name, it is replaced with a
zero-padded page range starting from 1
.IP \[bu]
Otherwise, if the output file name ends in .pdf (case insensitive), a
zero-padded page range, preceded by a dash, is inserted before the file
extension
.IP \[bu]
Otherwise, the file name is appended with a zero-padded page range
preceded by a dash.
Page ranges are single page numbers for single-page groups or first-last
for multi-page groups.
.TP
.B --overlay \-\- begin overlay options
--overlay file [options] --
Overlay pages from another file on the output.
Run qpdf --help=overlay-underlay for details.
.TP
.B --underlay \-\- begin underlay options
--underlay file [options] --
Underlay pages from another file on the output.
Run qpdf --help=overlay-underlay for details.
.TP
.B --flatten-rotation \-\- remove rotation from page dictionary
For each page that is rotated using the /Rotate key in the
page's dictionary, remove the /Rotate key and implement the
identical rotation semantics by modifying the page's contents.
This can be useful if a broken PDF viewer fails to properly
consider page rotation metadata.
.TP
.B --flatten-annotations \-\- push annotations into content
--flatten-annotations=parameter
Push page annotations into the content streams. This may be
necessary in some case when printing or splitting files.
Parameters: "all", "print", "screen".
.TP
.B --rotate \-\- rotate pages
--rotate=[+|-]angle[:page-range]
Rotate specified pages by multiples of 90 degrees specifying
either absolute or relative angles. "angle" may be 0, 90, 180,
or 270. You almost always want to use +angle or -angle rather
than just angle, as discussed in the manual. Run
qpdf --help=page-ranges for help with page ranges.
.TP
.B --generate-appearances \-\- generate appearances for form fields
PDF form fields consist of values and appearances, which may be
inconsistent with each other if a form field value has been
modified without updating its appearance. This option tells qpdf
to generate new appearance streams. There are some limitations,
which are discussed in the manual.
.TP
.B --optimize-images \-\- use efficient compression for images
Attempt to use DCT (JPEG) compression for images that fall
within certain constraints as long as doing so decreases the
size in bytes of the image. See also help for the following
options:
--oi-min-width
--oi-min-height
--oi-min-area
--keep-inline-images
.TP
.B --oi-min-width \-\- minimum width for --optimize-images
--oi-min-width=width
Don't optimize images whose width is below the specified value.
.TP
.B --oi-min-height \-\- minimum height for --optimize-images
--oi-min-height=height
Don't optimize images whose height is below the specified value.
.TP
.B --oi-min-area \-\- minimum area for --optimize-images
--oi-min-area=area-in-pixels
Don't optimize images whose area in pixels is below the specified value.
.TP
.B --keep-inline-images \-\- exclude inline images from optimization
Prevent inline images from being considered by --optimize-images.
.TP
.B --remove-page-labels \-\- remove explicit page numbers
Exclude page labels (explicit page numbers) from the output file.
.TP
.B --set-page-labels \-\- number pages for the entire document
--set-page-labels label-spec ... --
Set page labels (explicit page numbers) for the entire file.
Each label-spec has the form
first-page:[type][/start[/prefix]]
where
.IP \[bu]
"first-page" represents a sequential page number using the
same format as page ranges: a number, a number preceded by "r"
to indicate counting from the end, or "z" indicating the last
page
.IP \[bu]
"type" is one of
- D: Arabic numerals (digits)
- A: Upper-case alphabetic characters
- a: Lower-case alphabetic characters
- R: Upper-case Roman numerals
- r: Lower-case Roman numerals
- omitted: the page number does not appear, though the prefix,
if specified will still appear
.IP \[bu]
"prefix"` may be any string and is prepended to each page
label
A given page label spec causes pages to be numbered according to
that scheme starting with first-page and continuing until the
next label spec or the end of the document. If you want to omit
numbering starting at a certain page, you can use first-page: as
the spec.
Example: "1:r 5:D" would number the first four pages i through
iv, then the remaining pages with Arabic numerals starting with
1 and continuing sequentially until the end of the document. For
additional examples, please consult the manual.
.SH ENCRYPTION (create encrypted files)
Create encrypted files. Usage:
--encrypt \
[--user-password=user-password] \
[--owner-password=owner-password] \
--bits=key-length [options] --
OR
--encrypt user-password owner-password key-length [options] --
The first form, with flags for the passwords and bit length, was
introduced in qpdf 11.7.0. Only the --bits option is is mandatory.
This form allows you to use any text as the password. If passwords
are specified, they must be given before the --bits option.
The second form has been in qpdf since the beginning and wil
continue to be supported. Either or both of user-password and
owner-password may be empty strings.
The key-length parameter must be either 40, 128, or 256. The user
and/or owner password may be omitted. Omitting either password
enables the PDF file to be opened without a password. Specifying
the same value for the user and owner password and specifying an
empty owner password are both considered insecure.
Encryption options are terminated by "--" by itself.
40-bit encryption is insecure, as is 128-bit encryption without
AES. Use 256-bit encryption unless you have a specific reason to
use an insecure format, such as testing or compatibility with very
old viewers. You must use the --allow-weak-crypto to create
encrypted files that use insecure cryptographic algorithms. The
--allow-weak-crypto flag appears outside of --encrypt ... --
(before --encrypt or after --).
Available options vary by key length. Not all readers respect all
restrictions. Different PDF readers respond differently to various
combinations of options. Sometimes a PDF viewer may show you
restrictions that differ from what you selected. This is probably
not a bug in qpdf.
Options for 40-bit only:
--annotate=[y|n] restrict comments, filling forms, and signing
--extract=[y|n] restrict text/graphic extraction
--modify=[y|n] restrict document modification
--print=[y|n] restrict printing
Options for 128-bit or 256-bit:
--accessibility=[y|n] restrict accessibility (usually ignored)
--annotate=[y|n] restrict commenting/filling form fields
--assemble=[y|n] restrict document assembly
--extract=[y|n] restrict text/graphic extraction
--form=[y|n] restrict filling form fields
--modify-other=[y|n] restrict other modifications
--modify=modify-opt control modify access by level
--print=print-opt control printing access
--cleartext-metadata prevent encryption of metadata
For 128-bit only:
--use-aes=[y|n] indicates whether to use AES encryption
--force-V4 forces use of V=4 encryption handler
For 256-bit only:
--force-R5 forces use of deprecated R=5 encryption
--allow-insecure allow user password with empty owner password
Values for print-opt:
none disallow printing
low allow only low-resolution printing
full allow full printing
Values for modify-opt:
none allow no modifications
assembly allow document assembly only
form assembly + filling in form fields and signing
annotate form + commenting and modifying forms
all allow full document modification
.PP
Related Options:
.TP
.B --user-password \-\- specify user password
--user-password=user-password
Set the user password of the encrypted file.
.TP
.B --owner-password \-\- specify owner password
--owner-password=owner-password
Set the owner password of the encrypted file.
.TP
.B --bits \-\- specify encryption key length
--bits={48|128|256}
Specify the encryption key length. For best security, always use
a key length of 256.
.TP
.B --accessibility \-\- restrict document accessibility
--accessibility=[y|n]
This option is ignored except with very old encryption formats.
The current PDF specification does not allow restriction of
document accessibility. This option is not available with 40-bit
encryption.
.TP
.B --annotate \-\- restrict document annotation
--annotate=[y|n]
Enable/disable modifying annotations including making comments
and filling in form fields. For 128-bit and 256-bit encryption,
this also enables editing, creating, and deleting form fields
unless --modify-other=n or --modify=none is also specified.
.TP
.B --assemble \-\- restrict document assembly
--assemble=[y|n]
Enable/disable document assembly (rotation and reordering of
pages). This option is not available with 40-bit encryption.
.TP
.B --extract \-\- restrict text/graphic extraction
--extract=[y|n]
Enable/disable text/graphic extraction for purposes other than
accessibility.
.TP
.B --form \-\- restrict form filling
--form=[y|n]
Enable/disable whether filling form fields is allowed even if
modification of annotations is disabled. This option is not
available with 40-bit encryption.
.TP
.B --modify-other \-\- restrict other modifications
--modify-other=[y|n]
Enable/disable modifications not controlled by --assemble,
--annotate, or --form. --modify-other=n is implied by any of the
other --modify options. This option is not available with 40-bit
encryption.
.TP
.B --modify \-\- restrict document modification
--modify=modify-opt
For 40-bit files, modify-opt may only be y or n and controls all
aspects of document modification.
For 128-bit and 256-bit encryption, modify-opt values allow
enabling and disabling levels of restriction in a manner similar
to how some PDF creation tools do it. modify-opt values map to
other combinations of options as follows:
all: allow full modification (the default)
annotate: --modify-other=n
form: --modify-other=n --annotate=n
assembly: --modify-other=n --annotate=n --form=n
none: --modify-other=n --annotate=n --form=n --assemble=n
.TP
.B --print \-\- restrict printing
--print=print-opt
Control what kind of printing is allowed. For 40-bit encryption,
print-opt may only be y or n and enables or disables all
printing. For 128-bit and 256-bit encryption, print-opt may have
the following values:
none: disallow printing
low: allow low-resolution printing only
full: allow full printing (the default)
.TP
.B --cleartext-metadata \-\- don't encrypt metadata
If specified, don't encrypt document metadata even when
encrypting the rest of the document. This option is not
available with 40-bit encryption.
.TP
.B --use-aes \-\- use AES with 128-bit encryption
--use-aes=[y|n]
Enables/disables use of the more secure AES encryption with
128-bit encryption. Specifying --use-aes=y forces the PDF
version to be at least 1.6. This option is only available with
128-bit encryption. The default is "n" for compatibility
reasons. Use 256-bit encryption instead.
.TP
.B --allow-insecure \-\- allow empty owner passwords
Allow creation of PDF files with empty owner passwords and
non-empty user passwords when using 256-bit encryption.
.TP
.B --force-V4 \-\- force V=4 in encryption dictionary
This option is for testing and is never needed in practice since
qpdf does this automatically when needed.
.TP
.B --force-R5 \-\- use unsupported R=5 encryption
Use an undocumented, unsupported, deprecated encryption
algorithm that existed only in Acrobat version IX. This option
should not be used except for compatibility testing.
.SH PAGE-SELECTION (select pages from one or more files)
Use the --pages option to select pages from multiple files. Usage:
qpdf in.pdf --pages --file=input-file \
[--range=page-range] [--password=password] [...] -- out.pdf
OR
qpdf in.pdf --pages input-file [--password=password] [page-range] \
[...] -- out.pdf
Between --pages and the -- that terminates pages option, repeat
the following:
--file=filename [--range=page-range] [--password=password] [options]
For compatibility, the file and range can be specified
positionally. qpdf versions prior to 11.9.0
require --password=password to immediately follow the filename. In
the older syntax, repeat the following:
filename [--password=password] [page-range]
Document-level information, such as outlines, tags, etc., is taken
from in.pdf and is preserved in out.pdf. You can use --empty in place
of an input file to start from an empty file and just copy pages
equally from all files. You can use "." as a shorthand for the
primary input file (if not --empty). In the above example, "."
would refer to in.pdf.
Use --password=password to specify the password for a
password-protected input file. If the same input file is used more
than once, you only need to supply the password the first time. If
the page range is omitted, all pages are selected.
Run qpdf --help=page-ranges for help with page ranges.
Use --collate=n to cause pages to be collated in groups of n pages
(default 1) instead of concatenating the input.
Use --collate=i,j,k,... to take i from the first, then j from the
second, then k from the third, then i from the first, etc.
Examples:
.IP \[bu]
Start with in.pdf and append all pages from a.pdf and the even
pages from b.pdf, and write the output to out.pdf. Document-level
information from in.pdf is retained. Note the use of "." to refer
to in.pdf.
qpdf in.pdf --pages . a.pdf b.pdf 1-z:even -- out.pdf
.IP \[bu]
Take all the pages from a.pdf, all the pages from b.pdf in
reverse, and only pages 3 and 6 from c.pdf and write the result
to out.pdf. Use password "x" to open b.pdf:
qpdf --empty --pages a.pdf b.pdf --password=x z-1 c.pdf 3,6
More examples are in the manual.
.SH OVERLAY-UNDERLAY (overlay/underlay pages from other files)
These options allow pages from another file to be overlaid or
underlaid on the primary output. Overlaid pages are drawn on top of
the destination page and may obscure the page. Underlaid pages are
drawn below the destination page. Usage:
{--overlay|--underlay} [--file=]file
[--password=password]
[--to=page-range]
[--from=[page-range]]
[--repeat=page-range]
--
Note the use of "--" by itself to terminate overlay/underlay options.
For overlay and underlay, a file and optional password are specified, along
with a series of optional page ranges. The default behavior is that each
page of the overlay or underlay file is imposed on the corresponding page
of the primary output until it runs out of pages, and any extra pages are
ignored. You can also give a page range with --repeat to cause
those pages to be repeated after the original pages are exhausted.
This options are repeatable. Pages will be stacked in order of
appearance: first underlays, then the original page, then overlays.
Run qpdf --help=page-ranges for help with page ranges.
.PP
Related Options:
.TP
.B --to \-\- destination pages for underlay/overlay
--to=page-range
Specify the range of pages in the primary output to apply
overlay/underlay to. See qpdf --help=page-ranges for help with
the page range syntax.
.TP
.B --from \-\- source pages for underlay/overlay
--from=[page-range]
Specify pages from the overlay/underlay file that are applied to
the destination pages. See qpdf --help=page-ranges for help
with the page range syntax. The page range may be omitted
if --repeat is used.
.TP
.B --repeat \-\- overlay/underlay pages to repeat
--repeat=page-range
Specify pages from the overlay/underlay that are repeated after
"from" pages have been exhausted. See qpdf --help=page-ranges
for help with the page range syntax.
.SH ATTACHMENTS (work with embedded files)
It is possible to list, add, or delete embedded files (also known
as attachments) and to copy attachments from other files. See help
on individual options for details. Run qpdf --help=add-attachment
for additional details about adding attachments. See also
--help=--list-attachments and --help=--show-attachment.
.PP
Related Options:
.TP
.B --add-attachment \-\- start add attachment options
--add-attachment file [options] --
The --add-attachment flag and its options may be repeated to add
multiple attachments. Run qpdf --help=add-attachment for details.
.TP
.B --copy-attachments-from \-\- start copy attachment options
--copy-attachments-from file [options] --
The --copy-attachments-from flag and its options may be repeated
to copy attachments from multiple files. Run
qpdf --help=copy-attachments for details.
.TP
.B --remove-attachment \-\- remove an embedded file
--remove-attachment=key
Remove an embedded file using its key. Get the key with
--list-attachments.
.SH PDF-DATES (PDF date format)
When a date is required, the date should conform to the PDF date
format specification, which is "D:yyyymmddhhmmssz" where "z" is
either literally upper case "Z" for UTC or a timezone offset in
the form "-hh'mm'" or "+hh'mm'". Negative timezone offsets indicate
time before UTC. Positive offsets indicate how far after. For
example, US Eastern Standard Time (America/New_York) is "-05'00'",
and Indian Standard Time (Asia/Calcutta) is "+05'30'".
Examples:
.IP \[bu]
D:20210207161528-05'00' February 7, 2021 at 4:15:28 p.m.
.IP \[bu]
D:20210207211528Z February 7, 2021 at 21:15:28 UTC
.SH ADD-ATTACHMENT (attach (embed) files)
The options listed below appear between --add-attachment and its
terminating "--".
.PP
Related Options:
.TP
.B --key \-\- specify attachment key
--key=key
Specify the key to use for the attachment in the embedded files
table. It defaults to the last element (basename) of the
attached file's filename.
.TP
.B --filename \-\- set attachment's displayed filename
--filename=name
Specify the filename to be used for the attachment. This is what
is usually displayed to the user and is the name most graphical
PDF viewers will use when saving a file. It defaults to the last
element (basename) of the attached file's filename.
.TP
.B --creationdate \-\- set attachment's creation date
--creationdate=date
Specify the attachment's creation date in PDF format; defaults
to the current time. Run qpdf --help=pdf-dates for information
about the date format.
.TP
.B --moddate \-\- set attachment's modification date
--moddate=date
Specify the attachment's modification date in PDF format;
defaults to the current time. Run qpdf --help=pdf-dates for
information about the date format.
.TP
.B --mimetype \-\- attachment mime type, e.g. application/pdf
--mimetype=type/subtype
Specify the mime type for the attachment, such as text/plain,
application/pdf, image/png, etc.
.TP
.B --description \-\- set attachment's description
--description="text"
Supply descriptive text for the attachment, displayed by some
PDF viewers.
.TP
.B --replace \-\- replace attachment with same key
Indicate that any existing attachment with the same key should
be replaced by the new attachment. Otherwise, qpdf gives an
error if an attachment with that key is already present.
.SH COPY-ATTACHMENTS (copy attachments from another file)
The options listed below appear between --copy-attachments-from and
its terminating "--".
To copy attachments from a password-protected file, use
the --password option after the file name.
.PP
Related Options:
.TP
.B --prefix \-\- key prefix for copying attachments
--prefix=prefix
Prepend a prefix to each key; may be needed if there are
duplicate attachment keys. This affects the key only, not the
file name.
.SH INSPECTION (inspect PDF files)
These options provide tools for inspecting PDF files. When any of
the options in this section are specified, no output file may be
given.
.PP
Related Options:
.TP
.B --is-encrypted \-\- silently test whether a file is encrypted
Silently exit with a code indicating the file's encryption status:
0: the file is encrypted
1: not used
2: the file is not encrypted
This can be used with password-protected files even if you don't
know the password.
.TP
.B --requires-password \-\- silently test a file's password
Silently exit with a code indicating the file's password status:
0: a password, other than as supplied, is required
1: not used
2: the file is not encrypted
3: the file is encrypted, and correct password (if any) has been supplied
.TP
.B --check \-\- partially check whether PDF is valid
Check the structure of the PDF file as well as a number of other
aspects of the file, and write information about the file to
standard output. Note that qpdf does not perform any validation
of the actual PDF page content or semantic correctness of the
PDF file. It merely checks that the PDF file is syntactically
valid. See also qpdf --help=exit-status.
.TP
.B --show-encryption \-\- information about encrypted files
Show document encryption parameters. Also show the document's
user password if the owner password is given and the file was
encrypted using older encryption formats that allow user
password recovery.
.TP
.B --show-encryption-key \-\- show key with --show-encryption
When used with --show-encryption or --check, causes the
underlying encryption key to be displayed.
.TP
.B --check-linearization \-\- check linearization tables
Check to see whether a file is linearized and, if so, whether
the linearization hint tables are correct.
.TP
.B --show-linearization \-\- show linearization hint tables
Check and display all data in the linearization hint tables.
.TP
.B --show-xref \-\- show cross reference data
Show the contents of the cross-reference table or stream (object
locations in the file) in a human-readable form. This is
especially useful for files with cross-reference streams, which
are stored in a binary format.
.TP
.B --show-object \-\- show contents of an object
--show-object={trailer|obj[,gen]}
Show the contents of the given object. This is especially useful
for inspecting objects that are inside of object streams (also
known as "compressed objects").
.TP
.B --raw-stream-data \-\- show raw stream data
When used with --show-object, if the object is a stream, write
the raw (compressed) binary stream data to standard output
instead of the object's contents. See also
--filtered-stream-data.
.TP
.B --filtered-stream-data \-\- show filtered stream data
When used with --show-object, if the object is a stream, write
the filtered (uncompressed, potentially binary) stream data to
standard output instead of the object's contents. See also
--raw-stream-data.
.TP
.B --show-npages \-\- show number of pages
Print the number of pages in the input file on a line by itself.
Useful for scripts.
.TP
.B --show-pages \-\- display page dictionary information
Show the object and generation number for each page dictionary
object and for each content stream associated with the page.
.TP
.B --with-images \-\- include image details with --show-pages
When used with --show-pages, also shows the object and
generation numbers for the image objects on each page.
.TP
.B --list-attachments \-\- list embedded files
Show the key and stream number for each embedded file. Combine
with --verbose for more detailed information.
.TP
.B --show-attachment \-\- export an embedded file
--show-attachment=key
Write the contents of the specified attachment to standard
output as binary data. Get the key with --list-attachments.
.SH JSON (JSON output for PDF information)
Show information about the PDF file in JSON format. Please see the
JSON chapter in the qpdf manual for details.
.PP
Related Options:
.TP
.B --json \-\- show file in JSON format
--json[=version]
Generate a JSON representation of the file. This is described in
depth in the JSON section of the manual. "version" may be a
specific version or "latest" (the default). Run qpdf --json-help
for a description of the generated JSON object.
.TP
.B --json-help \-\- show format of JSON output
--json-help[=version]
Describe the format of the JSON output by writing to standard
output a JSON object with the same keys and with values
containing descriptive text.
.TP
.B --json-key \-\- limit which keys are in JSON output
--json-key=key
This option is repeatable. If given, only the specified
top-level keys will be included in the JSON output. Otherwise,
all keys will be included. With --json-output, when not given,
only the "qpdf" key will appear in the output.
.TP
.B --json-object \-\- limit which objects are in JSON
--json-object={trailer|obj[,gen]}
This option is repeatable. If given, only specified objects will
be shown in the "objects" key of the JSON output. Otherwise, all
objects will be shown.
.TP
.B --json-stream-data \-\- how to handle streams in json output
--json-stream-data={none|inline|file}
When used with --json, this option controls whether streams in
json output should be omitted, written inline (base64-encoded)
or written to a file. If "file" is chosen, the file will be the
name of the output file appended with -nnn where nnn is the
object number. The prefix can be overridden with
--json-stream-prefix. The default is "none", except
when --json-output is specified, in which case the default is
"inline".
.TP
.B --json-stream-prefix \-\- prefix for json stream data files
--json-stream-prefix=file-prefix
When used with --json-stream-data=file, --json-stream-data=file-prefix
sets the prefix for stream data files, overriding the default,
which is to use the output file name. Whatever is given here
will be appended with -nnn to create the name of the file that
will contain the data for the stream stream in object nnn.
.TP
.B --json-output \-\- apply defaults for JSON serialization
--json-output[=version]
Implies --json=version. Changes default values for certain
options so that the JSON output written is the most faithful
representation of the original PDF and contains no additional
JSON keys. See also --json-stream-data, --json-stream-prefix,
and --decode-level.
.TP
.B --json-input \-\- input file is qpdf JSON
Treat the input file as a JSON file in qpdf JSON format. See the
"qpdf JSON Format" section of the manual for information about
how to use this option.
.TP
.B --update-from-json \-\- update a PDF from qpdf JSON
--update-from-json=qpdf-json-file
Update a PDF file from a JSON file. Please see the "qpdf JSON"
chapter of the manual for information about how to use this
option.
.SH TESTING (options for testing or debugging)
The options below are useful when writing automated test code that
includes files created by qpdf or when testing qpdf itself.
.PP
Related Options:
.TP
.B --static-id \-\- use a fixed document ID
Use a fixed value for the document ID. This is intended for
testing only. Never use it for production files. See also
qpdf --help=--deterministic-id.
.TP
.B --static-aes-iv \-\- use a fixed AES vector
Use a static initialization vector for AES-CBC. This is intended
for testing only so that output files can be reproducible. Never
use it for production files. This option is not secure since it
significantly weakens the encryption.
.TP
.B --linearize-pass1 \-\- save pass 1 of linearization
--linearize-pass1=file
Write the first pass of linearization to the named file. The
resulting file is not a valid PDF file. This option is useful only
for debugging qpdf.
.TP
.B --test-json-schema \-\- test generated json against schema
This is used by qpdf's test suite to check consistency between
the output of qpdf --json and the output of qpdf --json-help.
.TP
.B --report-memory-usage \-\- best effort report of memory usage
This is used by qpdf's performance test suite to report the
maximum amount of memory used in supported environments.
.SH SEE ALSO
.PP
For a summary of qpdf's options, please run \fBqpdf \-\-help\fR.
A complete manual can be found at https://qpdf.readthedocs.io.