Skip to main content

A package to provide pathlib like access to zip & tar archives.

Project description

archive-path

Build Status codecov.io PyPI version Conda Version

A package to provide pathlib like access to zip & tar archives.

Installation

$ pip install archive-path

Usage

For reading zip (ZipPath) or tar (TarPath) files:

from archive_path import TarPath, ZipPath

path = TarPath("path/to/file.tar.gz", mode="r:gz")

sub_path = path / "folder" / "file.txt"
assert sub_path.filepath == "path/to/file.tar.gz"
assert sub_path.at == "folder/file.txt"
assert sub_path.exists() and sub_path.is_file()
assert sub_path.parent.is_dir()
content = sub_path.read_text()

for sub_path in path.iterdir():
    print(sub_path)

For writing files, you should use within a context manager, or directly call the close method:

with TarPath("path/to/file.tar.gz", mode="w:gz") as path:

    (path / "new_file.txt").write_text("hallo world")
    # there are also some features equivalent to shutil
    (path / "other_file.txt").putfile("path/to/external_file.txt")
    (path / "other_folder").puttree("path/to/external_folder", pattern="**/*")

Note that archive formats do not allow to overwrite existing files (they will raise a FileExistsError).

For performant access to single files:

from archive_path import read_file_in_tar, read_file_in_zip

content = read_file_in_tar("path/to/file.tar.gz", "file.txt", encoding="utf8")

These methods allow for faster access to files (using less RAM) in archives containing 1000's of files. This is because, the archive's file index is only read until the path is found (discarding non-matches), rather than the standard tarfile/zipfile approach that is to read the entire index into memory first.

Windows compatibility

Paths within the archives are always read and written as being / delimited. This means that the package works on Windows, but will not be compatible with archives written outside this package with \\ path delimiters.

Development

See CONTRIBUTING.md for details on how to contribute to this package.

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

archive-path-0.4.2.tar.gz (19.4 kB view details)

Uploaded Source

Built Distribution

archive_path-0.4.2-py3-none-any.whl (18.9 kB view details)

Uploaded Python 3

File details

Details for the file archive-path-0.4.2.tar.gz.

File metadata

  • Download URL: archive-path-0.4.2.tar.gz
  • Upload date:
  • Size: 19.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.28.1

File hashes

Hashes for archive-path-0.4.2.tar.gz
Algorithm Hash digest
SHA256 75279003ea986a4f6748e299ba74d95e74ad75f1bd3ae02d35c125c749633a51
MD5 7fe3d126881790e1e99c262bc7cd932d
BLAKE2b-256 f5cda4f37a093bcc424293c9eec88a20ff1881ad1983ebb7c7f95d4428981371

See more details on using hashes here.

File details

Details for the file archive_path-0.4.2-py3-none-any.whl.

File metadata

File hashes

Hashes for archive_path-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 664909adb5b29c25f0c3e669637e2fa0f010b6458e6920d4e87a8c395ae5e93d
MD5 cb1e4daad1b355c94c64dea337073f5d
BLAKE2b-256 75ff0c802d4d776db24570b309bfae4d15e3c3246c78b96bcc87893fe6979de9

See more details on using hashes here.

Supported by

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