pdftkversion 2.02- Check version history for changes
- See server manual for the latest documentation
PDFtk is a command-line utility for manipulating PDF documents. It enables operations including merging, splitting, rotating, encrypting, decrypting, watermarking, form-filling, and metadata extraction of PDF files.
pdftk [input PDF files | - | PROMPT]
[input_pw <passwords>]
[<operation>] [<operation arguments>]
[output <filename | - | PROMPT>]
[encrypt_40bit | encrypt_128bit]
[allow <permissions>]
[owner_pw <password>] [user_pw <password>]
[compress | uncompress]
[flatten] [need_appearances]
[verbose] [dont_ask | do_ask]
Input PDF Files: Specify one or more PDFs. Use - for stdin or PROMPT for interactive input. Files may be assigned handles (single uppercase letters) for reference in operations:
pdftk A=file1.pdf B=file2.pdf cat A B output merged.pdf
Input Passwords (input_pw): For encrypted PDFs, provide owner or user passwords associated with file handles or by input order:
pdftk A=secured.pdf input_pw A=foopass cat output unsecured.pdf
Merge, split, or reorder pages with optional rotation. Supports page ranges, reverse ordering (prefix r), page qualifiers (even/odd), and rotation (compass directions north, south, east, west, left, right, down).
Page range syntax: [handle][begin[-end[qualifier]]][rotation]
pdftk A=in1.pdf B=in2.pdf cat A1-7 B1-5 A8 output combined.pdf
Takes one page from each input range in turn, producing an interleaved result. Useful for collating separately scanned odd and even pages.
pdftk A=even.pdf B=odd.pdf shuffle A B output collated.pdf
Splits a single PDF into one file per page. Output files are named using printf-style formatting (default: pg_%04d.pdf).
pdftk input.pdf burst output page_%02d.pdf
Rotates specified pages while maintaining document order. Uses the same page range syntax as cat.
pdftk in.pdf cat 1-endeast output rotated.pdf
Creates an FDF file from a PDF form, capturing current field values.
pdftk form.pdf generate_fdf output form_data.fdf
Fills PDF form fields from an FDF or XFDF data file.
pdftk form.pdf fill_form data.fdf output filled.pdf flatten
Applies a single-page PDF as a background (watermark) behind every page of the input. The input PDF should have a transparent background for best results.
pdftk input.pdf background watermark.pdf output watermarked.pdf
Like background, but applies corresponding pages from the background PDF to matching pages in the input.
pdftk input.pdf multibackground watermarks.pdf output watermarked.pdf
Stamps a single-page PDF on top of every page of the input. Use this instead of background when the overlay PDF is opaque or has no transparency.
pdftk input.pdf stamp overlay.pdf output stamped.pdf
Like stamp, but applies corresponding pages from the stamp PDF to matching pages in the input.
pdftk input.pdf multistamp overlays.pdf output stamped.pdf
Outputs PDF metadata, bookmarks, and page metrics to a text file.
pdftk input.pdf dump_data output metadata.txt
Same as dump_data, but outputs UTF-8 encoded text.
pdftk input.pdf dump_data_utf8 output metadata_utf8.txt
Reports form field information including type, name, and values.
pdftk form.pdf dump_data_fields output fields.txt
Same as dump_data_fields, but outputs UTF-8 encoded text.
Reports PDF annotation information.
pdftk input.pdf dump_data_annots output annots.txt
Updates PDF metadata and bookmarks from a text file (same format as dump_data output).
pdftk input.pdf update_info metadata.txt output updated.pdf
Same as update_info, but expects UTF-8 encoded input.
Attaches files to a PDF, optionally at a specific page.
pdftk input.pdf attach_files table.html graph.png to_page 6 output output.pdf
Extracts file attachments from a PDF.
pdftk input.pdf unpack_files output /path/to/output/
| Option | Description |
|---|---|
output <filename> |
Specify output file. Use - for stdout or PROMPT for interactive. |
encrypt_40bit |
Apply 40-bit RC4 encryption |
encrypt_128bit |
Apply 128-bit RC4 encryption (default when password set) |
owner_pw <password> |
Set the owner password |
user_pw <password> |
Set the user password |
allow <permissions> |
Grant specific permissions (see below) |
compress |
Compress page streams |
uncompress |
Decompress page streams (useful for debugging) |
flatten |
Flatten form fields into page content |
need_appearances |
Signal viewer to regenerate field appearances |
keep_first_id |
Preserve document ID from first input |
keep_final_id |
Preserve document ID from last input |
drop_xfa |
Remove XFA form data |
verbose |
Enable detailed operation output |
dont_ask |
Suppress interactive prompts |
do_ask |
Enable interactive prompts |
Use with the allow keyword when encrypting. Available permissions:
| Permission | Description |
|---|---|
Printing |
Allow high-quality printing |
DegradedPrinting |
Allow low-quality printing |
ModifyContents |
Allow content modification |
Assembly |
Allow document assembly |
CopyContents |
Allow content copying |
ScreenReaders |
Allow screen reader access |
ModifyAnnotations |
Allow annotation modification |
FillIn |
Allow form fill-in |
AllFeatures |
Grant all permissions |
- Page numbers are one-based; use the
endkeyword for the final page - Handles are optional when working with a single PDF
- Filter mode (no operation specified) applies output options without restructuring
- Reverse page references use the
rprefix (e.g.,r1= last page,r2= second-to-last) - The
backgroundoperation requires a transparent input; usestampfor opaque overlay PDFs - Output filename cannot match any input filename