Main objects

class pikepdf.Pdf

In-memory representation of a PDF

property Root

The /Root object of the PDF.

add_blank_page(*, page_size=(612.0, 792.0))

Add a blank page to this PDF. If pages already exist, the page will be added to the end. Pages may be reordered using Pdf.pages.

The caller may add content to the page by modifying its objects after creating it.


page_size (tuple) – The size of the page in PDF units (1/72 inch or 0.35mm). Default size is set to a US Letter 8.5” x 11” page.

Return type


property allow: pikepdf.models.encryption.Permissions

Report permissions associated with this PDF.

By default these permissions will be replicated when the PDF is saved. Permissions may also only be changed when a PDF is being saved, and are only available for encrypted PDFs. If a PDF is not encrypted, all operations are reported as allowed.

pikepdf has no way of enforcing permissions.


Check if PDF is well-formed. Similar to qpdf --check.

Return type


check_linearization(self: pikepdf.Pdf, stream: object = sys.stderr) bool

Reports information on the PDF’s linearization.


stream – A stream to write this information too; must implement .write() and .flush() method. Defaults to sys.stderr.


True if the file is correctly linearized, and False if the file is linearized but the linearization data contains errors or was incorrectly generated.


RuntimeError – If the PDF in question is not linearized at all.


Close a Pdf object and release resources acquired by pikepdf.

If pikepdf opened the file handle it will close it (e.g. when opened with a file path). If the caller opened the file for pikepdf, the caller close the file. with blocks will call close when exit.

pikepdf lazily loads data from PDFs, so some pikepdf.Object may implicitly depend on the pikepdf.Pdf being open. This is always the case for pikepdf.Stream but can be true for any object. Do not close the Pdf object if you might still be accessing content from it.

When an Object is copied from one Pdf to another, the Object is copied into the destination Pdf immediately, so after accessing all desired information from the source Pdf it may be closed.


Closing the Pdf is currently implemented by resetting it to an empty sentinel. It is currently possible to edit the sentinel as if it were a live object. This behavior should not be relied on and is subject to change.

Return type


copy_foreign(self: pikepdf.Pdf, h: pikepdf.Object) pikepdf.Object

Copy an Object from a foreign Pdf to this one.

This function is used to copy a pikepdf.Object that is owned by some other Pdf into this one. This is performs a deep (recursive) copy and preserves circular references that may exist in the foreign object. It also copies all pikepdf.Stream objects. Since this may copy a large amount of data, it is not done implicitly. This function does not copy references to pages in the foreign PDF - it stops at page boundaries. Thus, if you use copy_foreign() on a table of contents (/Outlines dictionary), you may have to update references to pages.

Direct objects, including dictionaries, do not need copy_foreign(). pikepdf will automatically convert and construct them.


pikepdf automatically treats incoming pages from a foreign PDF as foreign objects, so Pdf.pages does not require this treatment.

Changed in version 2.1: Error messages improved.

property docinfo: pikepdf.objects.Dictionary

Access the (deprecated) document information dictionary.

The document information dictionary is a brief metadata record that can store some information about the origin of a PDF. It is deprecated and removed in the PDF 2.0 specification (not deprecated from the perspective of pikepdf). Use the .open_metadata() API instead, which will edit the modern (and unfortunately, more complicated) XMP metadata object and synchronize changes to the document information dictionary.

This property simplifies access to the actual document information dictionary and ensures that it is created correctly if it needs to be created.

A new, empty dictionary will be created if this property is accessed and dictionary does not exist. (This is to ensure that convenient code like pdf.docinfo[Name.Title] = "Title" will work when the dictionary does not exist at all.)

You can delete the document information dictionary by deleting this property, del pdf.docinfo. Note that accessing the property after deleting it will re-create with a new, empty dictionary.

property encryption: pikepdf.models.encryption.EncryptionInfo

Report encryption information for this PDF.

Encryption settings may only be changed when a PDF is saved.

property filename

The source filename of an existing PDF, when available.

flatten_annotations(self: pikepdf.Pdf, mode: str = 'all') None

Flattens all PDF annotations into regular PDF content.

Annotations are markup such as review comments, highlights, proofreading marks. User data entered into interactive form fields also counts as an annotation.

When annotations are flattened, they are “burned into” the regular content stream of the document and the fact that they were once annotations is deleted. This can be useful when preparing a document for printing, to ensure annotations are printed, or to finalize a form that should no longer be changed.


mode – One of the strings 'all', 'screen', 'print'. If omitted or set to empty, treated as 'all'. 'screen' flattens all except those marked with the PDF flag /NoView. 'print' flattens only those marked for printing.

New in version 2.11.

generate_appearance_streams(self: pikepdf.Pdf) None

Generates appearance streams for AcroForm forms and form fields.

Appearance streams describe exactly how annotations and form fields should appear to the user. If omitted, the PDF viewer is free to render the annotations and form fields according to its own settings, as needed.

For every form field in the document, this generates appearance streams, subject to the limitations of QPDF’s ability to create appearance streams.

When invoked, this method will modify the Pdf in memory. It may be best to do this after the Pdf is opened, or before it is saved, because it may modify objects that the user does not expect to be modified.


New in version 2.11.

get_object(*args, **kwargs)

Overloaded function.

  1. get_object(self: pikepdf.Pdf, objgen: Tuple[int, int]) -> pikepdf.Object

    Look up an object by ID and generation number

    Return type:


  2. get_object(self: pikepdf.Pdf, objid: int, gen: int) -> pikepdf.Object

    Look up an object by ID and generation number

    Return type:


get_warnings(self: pikepdf.Pdf) list
property is_encrypted

Returns True if the PDF is encrypted.

For information about the nature of the encryption, see Pdf.encryption.

property is_linearized

Returns True if the PDF is linearized.

Specifically returns True iff the file starts with a linearization parameter dictionary. Does no additional validation.

make_indirect(*args, **kwargs)

Overloaded function.

  1. make_indirect(self: pikepdf.Pdf, h: pikepdf.Object) -> pikepdf.Object

    Attach an object to the Pdf as an indirect object

    Direct objects appear inline in the binary encoding of the PDF. Indirect objects appear inline as references (in English, “look up object 4 generation 0”) and then read from another location in the file. The PDF specification requires that certain objects are indirect - consult the PDF specification to confirm.

    Generally a resource that is shared should be attached as an indirect object. pikepdf.Stream objects are always indirect, and creating them will automatically attach it to the Pdf.

    See Also:


    Return type:


  2. make_indirect(self: pikepdf.Pdf, obj: object) -> pikepdf.Object

    Encode a Python object and attach to this Pdf as an indirect object.

    Return type:


make_stream(data, d=None, **kwargs)

Create a new pikepdf.Stream object that is attached to this PDF.




data (bytes) –

Return type


static new() pikepdf.Pdf

Create a new empty PDF from stratch.

property objects

Return an iterable list of all objects in the PDF.

After deleting content from a PDF such as pages, objects related to that page, such as images on the page, may still be present.

Retun type:


open(password='', hex_password=False, ignore_xref_streams=False, suppress_warnings=True, attempt_recovery=True, inherit_page_attributes=True, access_mode=<AccessMode.default: 0>, allow_overwriting_input=False)

Open an existing file at filename_or_stream.

If filename_or_stream is path-like, the file will be opened for reading. The file should not be modified by another process while it is open in pikepdf, or undefined behavior may occur. This is because the file may be lazily loaded. Despite this restriction, pikepdf does not try to use any OS services to obtain an exclusive lock on the file. Some applications may want to attempt this or copy the file to a temporary location before editing. This behaviour changes if allow_overwriting_input is set: the whole file is then read and copied to memory, so that pikepdf can overwrite it when calling .save().

When this function is called with a stream-like object, you must ensure that the data it returns cannot be modified, or undefined behavior will occur.

Any changes to the file must be persisted by using .save().

If filename_or_stream has .read() and .seek() methods, the file will be accessed as a readable binary stream. pikepdf will read the entire stream into a private buffer.

.open() may be used in a with-block; .close() will be called when the block exits, if applicable.

Whenever pikepdf opens a file, it will close it. If you open the file for pikepdf or give it a stream-like object to read from, you must release that object when appropriate.


>>> with"test.pdf") as pdf:
>>> pdf ="test.pdf", password="rosebud")
  • filename_or_stream (Union[pathlib.Path, str, BinaryIO]) – Filename or Python readable and seekable file stream of PDF to open.

  • password (Union[str, bytes]) – User or owner password to open an encrypted PDF. If the type of this parameter is str it will be encoded as UTF-8. If the type is bytes it will be saved verbatim. Passwords are always padded or truncated to 32 bytes internally. Use ASCII passwords for maximum compatibility.

  • hex_password (bool) – If True, interpret the password as a hex-encoded version of the exact encryption key to use, without performing the normal key computation. Useful in forensics.

  • ignore_xref_streams (bool) – If True, ignore cross-reference streams. See qpdf documentation.

  • suppress_warnings (bool) – If True (default), warnings are not printed to stderr. Use pikepdf.Pdf.get_warnings() to retrieve warnings.

  • attempt_recovery (bool) – If True (default), attempt to recover from PDF parsing errors.

  • inherit_page_attributes (bool) – If True (default), push attributes set on a group of pages to individual pages

  • access_mode (pikepdf._qpdf.AccessMode) – If .default, pikepdf will decide how to access the file. Currently, it will always selected stream access. To attempt memory mapping and fallback to stream if memory mapping failed, use .mmap. Use .mmap_only to require memory mapping or fail (this is expected to only be useful for testing). Applications should be prepared to handle the SIGBUS signal on POSIX in the event that the file is successfully mapped but later goes away.

  • allow_overwriting_input (bool) – If True, allows calling .save() to overwrite the input file. This is performed by loading the entire input file into memory at open time; this will use more memory and may recent performance especially when the opened file will not be modified.

Return type



When filename_or_stream is a stream and the stream is located on a network, pikepdf assumes that the stream using buffering and read caches to achieve reasonable performance. Streams that fetch data over a network in response to every read or seek request, no matter how small, will perform poorly. It may be easier to download a PDF from network to temporary local storage (such as io.BytesIO), manipulate it, and then re-upload it.

open_metadata(set_pikepdf_as_editor=True, update_docinfo=True, strict=False)

Open the PDF’s XMP metadata for editing.

There is no .close() function on the metadata object, since this is intended to be used inside a with block only.

For historical reasons, certain parts of PDF metadata are stored in two different locations and formats. This feature coordinates edits so that both types of metadata are updated consistently and “atomically” (assuming single threaded access). It operates on the Pdf in memory, not any file on disk. To persist metadata changes, you must still use


>>> with pdf.open_metadata() as meta:
        meta['dc:title'] = 'Set the Dublic Core Title'
        meta['dc:description'] = 'Put the Abstract here'
  • set_pikepdf_as_editor (bool) – Automatically update the metadata pdf:Producer to show that this version of pikepdf is the most recent software to modify the metadata, and xmp:MetadataDate to timestamp the update. Recommended, except for testing.

  • update_docinfo (bool) – Update the standard fields of DocumentInfo (the old PDF metadata dictionary) to match the corresponding XMP fields. The mapping is described in PdfMetadata.DOCINFO_MAPPING. Nonstandard DocumentInfo fields and XMP metadata fields with no DocumentInfo equivalent are ignored.

  • strict (bool) – If False (the default), we aggressively attempt to recover from any parse errors in XMP, and if that fails we overwrite the XMP with an empty XMP record. If True, raise errors when either metadata bytes are not valid and well-formed XMP (and thus, XML). Some trivial cases that are equivalent to empty or incomplete “XMP skeletons” are never treated as errors, and always replaced with a proper empty XMP block. Certain errors may be logged.

Return type


open_outline(max_depth=15, strict=False)

Open the PDF outline (“bookmarks”) for editing.

Recommend for use in a with block. Changes are committed to the PDF when the block exits. (The Pdf must still be opened.)


>>> with pdf.open_outline() as outline:
        outline.root.insert(0, OutlineItem('Intro', 0))
  • max_depth (int) – Maximum recursion depth of the outline to be imported and re-written to the document. 0 means only considering the root level, 1 the first-level sub-outline of each root element, and so on. Items beyond this depth will be silently ignored. Default is 15.

  • strict (bool) – With the default behavior (set to False), structural errors (e.g. reference loops) in the PDF document will only cancel processing further nodes on that particular level, recovering the valid parts of the document outline without raising an exception. When set to True, any such error will raise an OutlineStructureError, leaving the invalid parts in place. Similarly, outline objects that have been accidentally duplicated in the Outline container will be silently fixed (i.e. reproduced as new objects) or raise an OutlineStructureError.

Return type


property owner_password_matched

Returns True if the owner password matched when the Pdf was opened.

It is possible for both the user and owner passwords to match.

New in version 2.10.

property pages

Returns the list of pages.

Return type:


property pdf_version

The version of the PDF specification used for this file, such as ‘1.7’.

remove_unreferenced_resources(self: pikepdf.Pdf) None

Remove from /Resources of each page any object not referenced in page’s contents

PDF pages may share resource dictionaries with other pages. If pikepdf is used for page splitting, pages may reference resources in their /Resources dictionary that are not actually required. This purges all unnecessary resource entries.

For clarity, if all references to any type of object are removed, that object will be excluded from the output PDF on save. (Conversely, only objects that are discoverable from the PDF’s root object are included.) This function removes objects that are referenced from the page /Resources dictionary, but never called for in the content stream, making them unnecessary.

Suggested before saving, if content streams or /Resources dictionaries are edited.

property root

Deprecated alias for .Root, the /Root object of the PDF.

Deprecated since version 2.0: Use .Root.

save(filename_or_stream=None, static_id=False, preserve_pdfa=True, min_version='', force_version='', fix_metadata_version=True, compress_streams=True, stream_decode_level=None, object_stream_mode=<ObjectStreamMode.preserve: 1>, normalize_content=False, linearize=False, qdf=False, progress=None, encryption=None, recompress_flate=False)

Save all modifications to this pikepdf.Pdf.

  • filename_or_stream (Optional[Union[pathlib.Path, str, BinaryIO]]) – Where to write the output. If a file exists in this location it will be overwritten. If the file was opened with allow_overwriting_input=True, then it is permitted to overwrite the original file, and this parameter may be omitted to implicitly use the original filename. Otherwise, the filename may not be the same as the input file, as overwriting the input file would corrupt data since pikepdf using lazy loading.

  • static_id (bool) – Indicates that the /ID metadata, normally calculated as a hash of certain PDF contents and metadata including the current time, should instead be generated deterministically. Normally for debugging.

  • preserve_pdfa (bool) – Ensures that the file is generated in a manner compliant with PDF/A and other stricter variants. This should be True, the default, in most cases.

  • min_version (Union[str, Tuple[str, int]]) – Sets the minimum version of PDF specification that should be required. If left alone QPDF will decide. If a tuple, the second element is an integer, the extension level. If the version number is not a valid format, QPDF will decide what to do.

  • force_version (Union[str, Tuple[str, int]]) – Override the version recommend by QPDF, potentially creating an invalid file that does not display in old versions. See QPDF manual for details. If a tuple, the second element is an integer, the extension level.

  • fix_metadata_version (bool) – If True (default) and the XMP metadata contains the optional PDF version field, ensure the version in metadata is correct. If the XMP metadata does not contain a PDF version field, none will be added. To ensure that the field is added, edit the metadata and insert a placeholder value in pdf:PDFVersion. If XMP metadata does not exist, it will not be created regardless of the value of this argument.

  • object_stream_mode (pikepdf._qpdf.ObjectStreamMode) – disable prevents the use of object streams. preserve keeps object streams from the input file. generate uses object streams wherever possible, creating the smallest files but requiring PDF 1.5+.

  • compress_streams (bool) – Enables or disables the compression of stream objects in the PDF that are created without specifying any compression setting. Metadata is never compressed. By default this is set to True, and should be except for debugging. Existing streams in the PDF or streams will not be modified. To decompress existing streams, you must set both compress_streams=False and stream_decode_level to the desired decode level (e.g. .generalized will decompress most non-image content).

  • stream_decode_level (Optional[pikepdf._qpdf.StreamDecodeLevel]) – Specifies how to encode stream objects. See documentation for pikepdf.StreamDecodeLevel.

  • recompress_flate (bool) – When disabled (the default), qpdf does not uncompress and recompress streams compressed with the Flate compression algorithm. If True, pikepdf will instruct qpdf to do this, which may be useful if recompressing streams to a higher compression level.

  • normalize_content (bool) – Enables parsing and reformatting the content stream within PDFs. This may debugging PDFs easier.

  • linearize (bool) – Enables creating linear or “fast web view”, where the file’s contents are organized sequentially so that a viewer can begin rendering before it has the whole file. As a drawback, it tends to make files larger.

  • qdf (bool) – Save output QDF mode. QDF mode is a special output mode in QPDF to allow editing of PDFs in a text editor. Use the program fix-qdf to fix convert back to a standard PDF.

  • progress (Optional[Callable[[int], None]]) – Specify a callback function that is called as the PDF is written. The function will be called with an integer between 0-100 as the sole parameter, the progress percentage. This function may not access or modify the PDF while it is being written, or data corruption will almost certainly occur.

  • encryption (Optional[Union[pikepdf.models.encryption.Encryption, bool]]) – If False or omitted, existing encryption will be removed. If True encryption settings are copied from the originating PDF. Alternately, an Encryption object may be provided that sets the parameters for new encryption.

Return type


You may call .save() multiple times with different parameters to generate different versions of a file, and you may continue to modify the file after saving it. .save() does not modify the Pdf object in memory, except possibly by updating the XMP metadata version with fix_metadata_version.


pikepdf.Pdf.remove_unreferenced_resources() before saving may eliminate unnecessary resources from the output file if there are any objects (such as images) that are referenced in a page’s Resources dictionary but never called in the page’s content stream.


pikepdf can read PDFs with incremental updates, but always coalesces any incremental updates into a single non-incremental PDF file when saving.

Changed in version 2.7: Added recompress_flate.

show_xref_table(self: pikepdf.Pdf) None

Pretty-print the Pdf’s xref (cross-reference table)

property trailer

Provides access to the PDF trailer object.

See PDF 1.7 Reference Manual section 7.5.5. Generally speaking, the trailer should not be modified with pikepdf, and modifying it may not work. Some of the values in the trailer are automatically changed when a file is saved.

property user_password_matched

Returns True if the user password matched when the Pdf was opened.

It is possible for both the user and owner passwords to match.

New in version 2.10.

Alias for

Alias for

class pikepdf.ObjectStreamMode

Options for saving streams within PDFs, which are more a compact way of saving certains types of data that was added in PDF 1.5. All modern PDF viewers support object streams, but some third party tools and libraries cannot read them.


Disable the use of object streams. If any object streams exist in the file, remove them when the file is saved.


Preserve any existing object streams in the original file. This is the default behavior.


Generate object streams.

class pikepdf.StreamDecodeLevel

Options for decoding streams within PDFs.


Do not attempt to apply any filters. Streams remain as they appear in the original file. Note that uncompressed streams may still be compressed on output. You can disable that by saving with .save(..., compress_streams=False).


This is the default. libqpdf will apply LZWDecode, ASCII85Decode, ASCIIHexDecode, and FlateDecode filters on the input. When saved with compress_streams=True, the default, the effect of this is that streams filtered with these older and less efficient filters will be recompressed with the Flate filter. As a special case, if a stream is already compressed with FlateDecode and compress_streams=True, the original compressed data will be preserved.


In addition to uncompressing the generalized compression formats, supported non-lossy compression will also be be decoded. At present, this includes the RunLengthDecode filter.


In addition to generalized and non-lossy specialized filters, supported lossy compression filters will be applied. At present, this includes DCTDecode (JPEG) compression. Note that compressing the resulting data with DCTDecode again will accumulate loss, so avoid multiple compression and decompression cycles. This is mostly useful for (low-level) retrieving image data; see pikepdf.PdfImage for the preferred method.

class pikepdf.Encryption(*, owner, user, R=6, allow=Permissions(accessibility=True, extract=True, modify_annotation=True, modify_assembly=False, modify_form=True, modify_other=True, print_lowres=True, print_highres=True), aes=True, metadata=True)

Specify the encryption settings to apply when a PDF is saved.

  • owner (str) – The owner password to use. This allows full control of the file. If blank, the PDF will be encrypted and present as “(SECURED)” in PDF viewers. If the owner password is blank, the user password should be as well.

  • user (str) – The user password to use. With this password, some restrictions will be imposed by a typical PDF reader. If blank, the PDF can be opened by anyone, but only modified as allowed by the permissions in allow.

  • R (int) – Select the security handler algorithm to use. Choose from: 2, 3, 4 or 6. By default, the highest version of is selected (6). 5 is a deprecated algorithm that should not be used.

  • allow (pikepdf.models.encryption.Permissions) – The permissions to set. If omitted, all permissions are granted to the user.

  • aes (bool) – If True, request the AES algorithm. If False, use RC4. If omitted, AES is selected whenever possible (R >= 4).

  • metadata (bool) – If True, also encrypt the PDF metadata. If False, metadata is not encrypted. Reading document metadata without decryption may be desirable in some cases. Requires aes=True. If omitted, metadata is encrypted whenever possible.

Object construction

class pikepdf.Object
append(self: pikepdf.Object, arg0: object) None

Append another object to an array; fails if the object is not an array.

as_dict(self: pikepdf.Object) pikepdf._ObjectMapping
as_list(self: pikepdf.Object) pikepdf._ObjectList
emplace(other, retain=(pikepdf.Name('/Parent'),))

Copy all items from other without making a new object.

Particularly when working with pages, it may be desirable to remove all of the existing page’s contents and emplace (insert) a new page on top of it, in a way that preserves all links and references to the original page. (Or similarly, for other Dictionary objects in a PDF.)

Any Dictionary keys in the iterable retain are preserved. By default, /Parent is retained.

When a page is assigned (pdf.pages[0] = new_page), only the application knows if references to the original the original page are still valid. For example, a PDF optimizer might restructure a page object into another visually similar one, and references would be valid; but for a program that reorganizes page contents such as a N-up compositor, references may not be valid anymore.

This method takes precautions to ensure that child objects in common with self and other are not inadvertently deleted.


>>> pdf.pages[0].objgen
(16, 0)
>>> pdf.pages[0].emplace(pdf.pages[1])
>>> pdf.pages[0].objgen
(16, 0)  # Same object

Changed in version 2.11.1: Added the retain argument.


other (pikepdf.objects.Object) –

extend(self: pikepdf.Object, arg0: Iterable) None

Extend a pikepdf.Array with an iterable of other objects.

get(*args, **kwargs)

Overloaded function.

  1. get(self: pikepdf.Object, key: str, default: object = None) -> object

For pikepdf.Dictionary or pikepdf.Stream objects, behave as dict.get(key, default=None)

  1. get(self: pikepdf.Object, key: pikepdf.Object, default: object = None) -> object

For pikepdf.Dictionary or pikepdf.Stream objects, behave as dict.get(key, default=None)

get_raw_stream_buffer(self: pikepdf.Object) pikepdf.Buffer

Return a buffer protocol buffer describing the raw, encoded stream

get_stream_buffer(self: pikepdf.Object, decode_level: pikepdf.StreamDecodeLevel = <StreamDecodeLevel.generalized: 1>) pikepdf.Buffer

Return a buffer protocol buffer describing the decoded stream.

is_owned_by(self: pikepdf.Object, possible_owner: pikepdf.Pdf) bool

Test if this object is owned by the indicated possible_owner.

property is_rectangle

Returns True if the object is a rectangle (an array of 4 numbers)

items(self: pikepdf.Object) Iterable
keys(self: pikepdf.Object) Set[str]

For pikepdf.Dictionary or pikepdf.Stream objects, obtain the keys.

property objgen

Return the object-generation number pair for this object.

If this is a direct object, then the returned value is (0, 0). By definition, if this is an indirect object, it has a “objgen”, and can be looked up using this in the cross-reference (xref) table. Direct objects cannot necessarily be looked up.

The generation number is usually 0, except for PDFs that have been incrementally updated. Incrementally updated PDFs are now uncommon, since it does not take too long for modern CPUs to reconstruct an entire PDF. pikepdf will consolidate all incremental updates when saving.

page_contents_add(self: pikepdf.Object, contents: pikepdf.Object, prepend: bool = False) None

Append or prepend to an existing page’s content stream.

Deprecated since version 2.14: Use pikepdf.Page.contents_add() instead.

page_contents_coalesce(self: pikepdf.Object) None

Coalesce an array of page content streams into a single content stream.

Deprecated since version 2.14: Use pikepdf.Page.contents_coalesce() instead.

static parse(stream: str, description: str = '') pikepdf.Object

Parse PDF binary representation into PDF objects.

read_bytes(self: pikepdf.Object, decode_level: pikepdf.StreamDecodeLevel = <StreamDecodeLevel.generalized: 1>) bytes

Decode and read the content stream associated with this object.

read_raw_bytes(self: pikepdf.Object) bytes

Read the content stream associated with this object without decoding

same_owner_as(self: pikepdf.Object, arg0: pikepdf.Object) bool

Test if two objects are owned by the same pikepdf.Pdf.

property stream_dict

Access the dictionary key-values for a pikepdf.Stream.

to_json(self: pikepdf.Object, dereference: bool = False) bytes

Convert to a QPDF JSON representation of the object.

See the QPDF manual for a description of its JSON representation.

Not necessarily compatible with other PDF-JSON representations that exist in the wild.

  • Names are encoded as UTF-8 strings

  • Indirect references are encoded as strings containing obj gen R

  • Strings are encoded as UTF-8 strings with unrepresentable binary characters encoded as \uHHHH

  • Encoding streams just encodes the stream’s dictionary; the stream data is not represented

  • Object types that are only valid in content streams (inline image, operator) as well as “reserved” objects are not representable and will be serialized as null.


dereference (bool) – If True, dereference the object is this is an indirect object.


JSON bytestring of object. The object is UTF-8 encoded and may be decoded to a Python str that represents the binary values \x00-\xFF as U+0000 to U+00FF; that is, it may contain mojibake.

Return type


unparse(self: pikepdf.Object, resolved: bool = False) bytes

Convert PDF objects into their binary representation, optionally resolving indirect objects.

with_same_owner_as(self: pikepdf.Object, arg0: pikepdf.Object) pikepdf.Object

Returns an object that is owned by the same Pdf that owns the other object.

If the objects already have the same owner, this object is returned. If the other object has a different owner, then a copy is created that is owned by other’s owner. If this object is a direct object (no owner), then an indirect object is created that is owned by other. An exception is thrown if other is a direct object.

This method may be convenient when a reference to the Pdf is not available.

..versionadded:: 2.14

wrap_in_array(self: pikepdf.Object) pikepdf.Object

Return the object wrapped in an array if not already an array.

write(data, *, filter=None, decode_parms=None, type_check=True)

Replace stream object’s data with new (possibly compressed) data.

filter and decode_parms specify that compression that is present on the input data.

When writing the PDF in, pikepdf may change the compression or apply compression to data that was not compressed, depending on the parameters given to that function. It will never change lossless to lossy encoding.

PNG and TIFF images, even if compressed, cannot be directly inserted into a PDF and displayed as images.


If only one filter is specified, it may be a name such as Name(‘/FlateDecode’). If there are multiple filters, then array of names should be given.

If there is only one filter, decode_parms is a Dictionary of parameters for that filter. If there are multiple filters, then decode_parms is an Array of Dictionary, where each array index is corresponds to the filter.

class pikepdf.Name(name)

Constructs a PDF Name object.

Names can be constructed with two notations:

  1. Name.Resources

  2. Name('/Resources')

The two are semantically equivalent. The former is preferred for names that are normally expected to be in a PDF. The latter is preferred for dynamic names and attributes.


name (str) –

static __new__(cls, name)

name (str) –

class pikepdf.String(s)

Constructs a PDF String object.


s (Union[str, bytes]) –

static __new__(cls, s)

s (Union[str, bytes]) –

class pikepdf.Array(a=None)

Constructs a PDF Array object.


a (Optional[Union[Iterable, pikepdf._qpdf.Rectangle]]) –

static __new__(cls, a=None)

a (Optional[Union[Iterable, pikepdf._qpdf.Rectangle]]) –

class pikepdf.Dictionary(d=None, **kwargs)

Constructs a PDF Dictionary object.

static __new__(cls, d=None, **kwargs)
class pikepdf.Stream(owner, data=None, d=None, **kwargs)

Constructs a PDF Stream object.

static __new__(cls, owner, data=None, d=None, **kwargs)
class pikepdf.Operator(name)

Constructs an operator for use in a content stream.

An Operator is one of a limited set of commands that can appear in PDF content streams (roughly the mini-language that draws objects, lines and text on a virtual PDF canvas). The commands parse_content_stream() and unparse_content_stream() create and expect Operators respectively, along with their operands.

pikepdf uses the special Operator “INLINE IMAGE” to denote an inline image in a content stream.


name (str) –

Common PDF data structures

class pikepdf.Rectangle

A PDF rectangle.

Typically this will be a rectangle in PDF units (points, 1/72”). Unlike raster graphics, the rectangle is defined by the lower left and upper right points.

Rectangles in PDF are encoded as pikepdf.Array with exactly four numeric elements, ordered as llx lly urx ury. See PDF 1.7 Reference Manual section 7.9.5.

The rectangle may be considered degenerate if the lower left corner is not strictly less than the upper right corner.

as_array(self: pikepdf.Rectangle) pikepdf.Object

Returns this rectangle as a pikepdf.Array.

property height

The height of the rectangle.

property llx

The lower left corner on the x-axis.

property lly

The lower left corner on the y-axis.

property lower_left

A point for the lower left corner.

property lower_right

A point for the lower right corner.

property upper_left

A point for the upper left corner.

property upper_right

A point for the upper right corner.

property urx

The upper right corner on the x-axis.

property ury

The upper right corner on the y-axis.

property width

The width of the rectangle.

Internal objects

These objects are returned by other pikepdf objects. They are part of the API, but not intended to be created explicitly.

class pikepdf._qpdf.PageList

A list-like object enumerating a range of pages in a pikepdf.Pdf. It may be all of the pages or a subset.

append(self: pikepdf.PageList, page: object) None

Add another page to the end.

extend(*args, **kwargs)

Overloaded function.

  1. extend(self: pikepdf.PageList, other: pikepdf.PageList) -> None

Extend the Pdf by adding pages from another Pdf.pages.

  1. extend(self: pikepdf.PageList, iterable: Iterable) -> None

Extend the Pdf by adding pages from an iterable of pages.

index(*args, **kwargs)

Overloaded function.

  1. index(self: pikepdf.PageList, arg0: pikepdf.Object) -> int

    Given a pikepdf.Object that is a page, find the index.

    That is, returns n such that pdf.pages[n] == this_page. A ValueError exception is thrown if the page does not belong to to this Pdf.

  2. index(self: pikepdf.PageList, arg0: pikepdf.Page) -> int

    Given a pikepdf.Page (page helper), find the index.

    That is, returns n such that pdf.pages[n] == this_page. A ValueError exception is thrown if the page does not belong to to this Pdf.

insert(self: pikepdf.PageList, index: int, obj: object) None

Insert a page at the specified location.

  • index (int) – location at which to insert page, 0-based indexing

  • obj (pikepdf.Object) – page object to insert

p(self: pikepdf.PageList, pnum: int) pikepdf.Object

Convenience - look up page number in ordinal numbering, .p(1) is first page

remove(self: pikepdf.PageList, **kwargs) None

Remove a page (using 1-based numbering)


p (int) – 1-based page number

reverse(self: pikepdf.PageList) None

Reverse the order of pages.