Skip to main content

extended pickle

Project description

Extends the original Pickler class to be able to pickle some otherwise non-supported types. The emphasis is to be fast and for communication via pipes/sockets with the same Python version on the other end - thus we don’t care that much for compatibility with other versions.

A similar project is dill, which is much bigger though.

This project is registered on PyPI and can be installed via

pip install extpickle

For some usage examples, see the test code.

Over the base Pickler class, it adds pickling support for:

  • types.FunctionType, types.CodeType and cell-types. I.e. you can pickle lamdas and functions. Note this will use the marshal module for the byte-code, so this is not portable across different Python versions.

  • Modules. This is done by referencing it via its name. Note that is has some extra handling for __main__, which is allowed to be a different module.

  • mod.__dict__ where mod is a module is also stored just as a reference to the module, not a copy of the dict.

  • (Python 2) buffer.

  • numpy.ndarray. This is also supported by the base class but our implementation is much faster. Actually this is a bit weird because the default implementation should also be just as fast but it isn’t. Our implementation basically just uses fromstring/tostring.

  • New-style classes. The base class would try to look them up in a module. This will fail whenever it cannot be find in such namespace. Our implementation, if that fails, will actually store the information to construct a new class, i.e. the name, the bases and its dict.

  • (Python 2) Old-style classes. This is the same behavior as for the new-style classes.

This was used in the TaskSystem project.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

extpickle-1.20160616.215241.tar.gz (5.4 kB view details)

Uploaded Source

File details

Details for the file extpickle-1.20160616.215241.tar.gz.

File metadata

File hashes

Hashes for extpickle-1.20160616.215241.tar.gz
Algorithm Hash digest
SHA256 a76655d220b1be23ea2d9852a0a3976086d3f88a29137cea7678e533770907ac
MD5 c33ab7a9976d6738133b8b301113b746
BLAKE2b-256 2dbe554918eddc77e6114f7c02d90792bc369d94d7406e123b850369215eb3d0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page