Pypdf

Latest version: v5.4.0

Safety actively analyzes 723625 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 14 of 15

2.4.0

New Features (ENH):
- Support R6 decrypting (1015)
- Add PdfReader.pdf_header (1013)

Performance Improvements (PI):
- Remove ord_ calls (1014)

Bug Fixes (BUG):
- Fix missing page for bookmark (1016)

Robustness (ROB):
- Deal with invalid Destinations (1028)

Documentation (DOC):
- get_form_text_fields does not extract dropdown data (1029)
- Adjust PdfWriter.add_uri docstring
- Mention crypto extra_requires for installation (1017)

Developer Experience (DEV):
- Use /n line endings everywhere (1027)
- Adjust string formatting to be able to use mutmut (1020)
- Update Bug report template

[Full Changelog](https://github.com/py-pdf/PyPDF2/compare/2.3.1...2.4.0)

2.3.1

BUG: Forgot to add the internal `_codecs` subpackage.

[Full Changelog](https://github.com/py-pdf/PyPDF2/compare/2.3.0...2.3.1)

2.3.0

The highlight of this release is improved support for file encryption
(AES-128 and AES-256, R5 only). See 749 for the amazing work of
exiledkingcc 🎊 Thank you 🤗

Deprecations (DEP)
- Rename names to be PEP8-compliant (967)
- `PdfWriter.get_page`: the pageNumber parameter is renamed to page_number
- `PyPDF2.filters`:
* For all classes, a parameter rename: decodeParms âž” decode_parms
* decodeStreamData âž” decode_stream_data
- `PyPDF2.xmp`:
* XmpInformation.rdfRoot âž” XmpInformation.rdf_root
* XmpInformation.xmp_createDate âž” XmpInformation.xmp_create_date
* XmpInformation.xmp_creatorTool âž” XmpInformation.xmp_creator_tool
* XmpInformation.xmp_metadataDate âž” XmpInformation.xmp_metadata_date
* XmpInformation.xmp_modifyDate âž” XmpInformation.xmp_modify_date
* XmpInformation.xmpMetadata âž” XmpInformation.xmp_metadata
* XmpInformation.xmpmm_documentId âž” XmpInformation.xmpmm_document_id
* XmpInformation.xmpmm_instanceId âž” XmpInformation.xmpmm_instance_id
- `PyPDF2.generic`:
* readHexStringFromStream âž” read_hex_string_from_stream
* initializeFromDictionary âž” initialize_from_dictionary
* createStringObject âž” create_string_object
* TreeObject.hasChildren âž” TreeObject.has_children
* TreeObject.emptyTree âž” TreeObject.empty_tree

New Features (ENH)
- Add decrypt support for V5 and AES-128, AES-256 (R5 only) (749)

Robustness (ROB)
- Fix corrupted (wrongly) linear PDF (1008)

Maintenance (MAINT)
- Move PDF_Samples folder into resources
- Fix typos (1007)

Testing (TST)
- Improve encryption/decryption test (1009)
- Add merger test cases with real PDFs (1006)
- Add mutmut config

Code Style (STY)
- Put pure data mappings in separate files (1005)
- Make encryption module private, apply pre-commit (1010)

[Full Changelog](https://github.com/py-pdf/PyPDF2/compare/2.2.1...2.3.0)

2.2.1

Performance Improvements (PI)
- Remove b_ calls (992, 986)
- Apply improvements to _utils suggested by perflint (993)

Robustness (ROB)
- utf-16-be codec can't decode (...) (995)

Documentation (DOC)
- Remove reference to Scripts (987)

Developer Experience (DEV)
- Fix type annotations for add_bookmarks (1000)

Testing (TST)
- Add test for PdfMerger (1001)
- Add tests for XMP information (996)
- reader.get_fields / zlib issue / LZW decode issue (1004)
- reader.get_fields with report generation (1002)
- Improve test coverage by extracting texts (998)

Code Style (STY)
- Apply fixes suggested by pylint (999)

[Full Changelog](https://github.com/py-pdf/PyPDF2/compare/2.2.0...2.2.1)

2.2.0

The 2.2.0 release improves text extraction again via (969):

* Improvements around /Encoding / /ToUnicode
* Extraction of CMaps improved
* Fallback for font def missing
* Support for /Identity-H and /Identity-V: utf-16-be
* Support for /GB-EUC-H / /GB-EUC-V / GBp/c-EUC-H / /GBpc-EUC-V (beta release for evaluation)
* Arabic (for evaluation)
* Whitespace extraction improvements

Those changes should mainly improve the text extraction for non-ASCII alphabets,
e.g. Russian / Chinese / Japanese / Korean / Arabic.

[Full Changelog](https://github.com/py-pdf/PyPDF2/compare/2.1.1...2.2.0)

2.1.1

New Features (ENH)
- Add support for pathlib as input for PdfReader (979)

Performance Improvements (PI)
- Optimize read_next_end_line (646)

Bug Fixes (BUG)
- Adobe Acrobat 'Would you like to save this file?' (970)

Documentation (DOC)
- Notes on annotations (982)
- Who uses PyPDF2
- intendet \xe2\x9e\x94 in robustness page (958)

Maintenance (MAINT)
- pre-commit / requirements.txt updates (977)
- Mark read_next_end_line as deprecated (965)
- Export `PageObject` in PyPDF2 root (960)

Testing (TST)
- Add MCVE of issue 416 (980)
- FlateDecode.decode decodeParms (964)
- Xmp module (962)
- utils.paeth_predictor (959)

Code Style (STY)
- Use more tuples and list/dict comprehensions (976)

[Full Changelog](https://github.com/py-pdf/PyPDF2/compare/2.1.0...2.1.1)

Page 14 of 15

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.