Python interface to libarchive
A Python interface to libarchive. It uses the standard ctypes module to dynamically load and access the C library.
pip install libarchive-c
python-libarchive-c is currently tested with python 2.7, 3.4, 3.5, and 3.6.
If you find an incompatibility with older versions you can send us a small patch, but we won’t accept big changes.
python-libarchive-c may not work properly with obsolete versions of libarchive such as the ones included in MacOS. In that case you can install a recent version of libarchive (e.g. with brew install libarchive on MacOS) and use the LIBARCHIVE environment variable to point python-libarchive-c to it:
To extract an archive to the current directory:
extract_memory extracts from a buffer instead, and extract_fd extracts from a file descriptor.
To read an archive:
with libarchive.file_reader('test.7z') as archive: for entry in archive: for block in entry.get_blocks(): ...
memory_reader reads from a memory buffer instead, and fd_reader reads from a file descriptor.
To create an archive:
with libarchive.file_writer('test.tar.gz', 'ustar', 'gzip') as archive: archive.add_files('libarchive/', 'README.rst')
memory_writer writes to a memory buffer instead, fd_writer writes to a file descriptor, and custom_writer sends the data to a callback function.
You can also find more thorough examples in the tests/ directory.
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size libarchive_c-2.9-py2.py3-none-any.whl (11.3 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View hashes|
|Filename, size libarchive-c-2.9.tar.gz (46.4 kB)||File type Source||Python version None||Upload date||Hashes View hashes|
Hashes for libarchive_c-2.9-py2.py3-none-any.whl