Python wrapper for 7zz CLI tool providing cross-platform compression with multiple archive formats
Project description
py7zz
A Python wrapper for 7zz CLI tool providing cross-platform archive operations with built-in security protection, Windows filename compatibility, and comprehensive API support.
Table of Contents
- Features
- Installation
- Quick Start
- API Reference
- Advanced Features
- Migration Guide
- Contributing
- License
Features
- Cross-platform: Windows, macOS, Linux
- 50+ formats: 7Z, ZIP, TAR, RAR, and more
- API compatible: Drop-in replacement for
zipfile/tarfile - Windows compatibility: Automatic filename sanitization
- Security protection: ZIP bomb detection and file count limits
- Async support: Non-blocking operations with progress
- Zero dependencies: Bundled 7zz binary
Installation
pip install py7zz
For development:
git clone https://github.com/rxchi1d/py7zz.git
cd py7zz
pip install -e .
Quick Start
Basic Usage
import py7zz
# Create archive
py7zz.create_archive('backup.7z', ['documents/', 'photos/'])
# Extract archive
py7zz.extract_archive('backup.7z', 'extracted/')
# List contents
with py7zz.SevenZipFile('backup.7z', 'r') as sz:
print(sz.namelist())
Drop-in Replacement
# OLD: zipfile
import zipfile
with zipfile.ZipFile('archive.zip', 'r') as zf:
zf.extractall('output/')
# NEW: py7zz (identical API)
import py7zz
with py7zz.SevenZipFile('archive.7z', 'r') as sz:
sz.extractall('output/')
Async Operations
import asyncio
import py7zz
async def main():
await py7zz.create_archive_async('backup.7z', ['data/'])
await py7zz.extract_archive_async('backup.7z', 'output/')
asyncio.run(main())
API Reference
Core Classes
SevenZipFile(file, mode='r', preset=None)
Main class for archive operations, compatible with zipfile.ZipFile.
Parameters:
file: Path to archivemode: 'r' (read), 'w' (write), 'a' (append)preset: Compression preset ('fast', 'balanced', 'ultra')
Methods:
namelist(): List all filesextractall(path, members): Extract filesadd(name, arcname): Add fileread(name): Read file contenttestzip(): Test integrity
Simple Functions
create_archive(path, files, preset='balanced')
Create archive from files.
extract_archive(path, output_dir='.')
Extract all files from archive.
test_archive(path)
Test archive integrity.
Security Features
SecurityConfig(max_file_count=5000, max_compression_ratio=100.0, max_total_size=10737418240)
Configure security limits for archive processing.
check_file_count_security(file_list, config=None)
Check if archive file count exceeds security limits.
Filename Utilities
sanitize_filename(filename)
Sanitize filename for Windows compatibility.
is_valid_windows_filename(filename)
Check if filename is valid on Windows.
get_safe_filename(filename, existing_names=None)
Get Windows-compatible filename with conflict resolution.
Async API
AsyncSevenZipFile
Async version of SevenZipFile with identical methods.
create_archive_async(), extract_archive_async()
Async versions of simple functions.
Configuration
Compression Presets
'fast': Quick compression'balanced': Default'ultra': Maximum compression
Logging
py7zz.setup_logging('INFO') # Configure logging
py7zz.disable_warnings() # Hide warnings
Exception Handling
py7zz provides specific exceptions for different error conditions:
from py7zz.exceptions import (
ZipBombError, # Potential ZIP bomb detected
SecurityError, # Security limits exceeded
PasswordRequiredError, # Archive requires password
FileNotFoundError, # File or archive not found
CorruptedArchiveError # Archive is corrupted
)
try:
py7zz.extract_archive('archive.7z')
except ZipBombError:
print("Archive may be a ZIP bomb")
except PasswordRequiredError:
print("Archive is password protected")
except CorruptedArchiveError:
print("Archive is corrupted")
See API Documentation for complete reference.
Migration Guide
From zipfile
# Change import
import py7zz # was: import zipfile
# Change class name
with py7zz.SevenZipFile('archive.7z', 'r') as sz: # was: zipfile.ZipFile
sz.extractall() # Same API!
From tarfile
# Change import
import py7zz # was: import tarfile
# Use same class
with py7zz.SevenZipFile('archive.tar.gz', 'r') as sz: # was: tarfile.open
sz.extractall() # Same API!
See Migration Guide for detailed instructions.
Supported Formats
| Format | Read | Write |
|---|---|---|
| 7Z | ✅ | ✅ |
| ZIP | ✅ | ✅ |
| TAR | ✅ | ✅ |
| RAR | ✅ | ❌ |
| GZIP | ✅ | ✅ |
| BZIP2 | ✅ | ✅ |
| XZ | ✅ | ✅ |
And 40+ more formats for reading.
Advanced Features
Security Protection
Built-in protection against malicious archives:
from py7zz import SecurityConfig, ZipBombError
# Configure security limits
config = SecurityConfig(max_file_count=1000, max_compression_ratio=50.0)
try:
py7zz.extract_archive('suspicious.zip')
except ZipBombError as e:
print(f"Potential ZIP bomb detected: {e}")
Windows Filename Compatibility
Automatically handles Windows restrictions and provides utilities:
from py7zz import sanitize_filename, is_valid_windows_filename
# Auto-sanitization during extraction
py7zz.extract_archive('unix-archive.tar.gz') # Files sanitized automatically
# Manual filename utilities
safe_name = sanitize_filename("invalid<file>name.txt") # → "invalid_file_name.txt"
is_valid = is_valid_windows_filename("CON.txt") # → False
Progress Monitoring
async def progress_callback(info):
print(f"Progress: {info.percentage:.1f}%")
await py7zz.extract_archive_async('large.7z', progress_callback=progress_callback)
Batch Operations
archives = ['backup1.7z', 'backup2.7z', 'backup3.7z']
py7zz.batch_extract_archives(archives, 'output/')
Development
Setup
# Clone repository
git clone https://github.com/rxchi1d/py7zz.git
cd py7zz
# Install dependencies (development mode)
uv sync --dev
uv pip install -e .
Testing
# Run tests
pytest
# Check code quality
ruff check .
mypy .
Code Style
- Follow PEP 8
- Use type hints
- Maximum line length: 88
- Format with
ruff format
Requirements
- Python 3.8+
- No external dependencies
- Supported platforms:
- Windows x64
- macOS (Intel & Apple Silicon)
- Linux x86_64
Version Information
py7zz follows PEP 440 versioning standard:
import py7zz
print(py7zz.get_version()) # py7zz version (e.g., "1.0.0")
print(py7zz.get_bundled_7zz_version()) # 7zz version
# Version types supported:
# - Stable: 1.0.0
# - Alpha: 1.0.0a1
# - Beta: 1.0.0b1
# - Release Candidate: 1.0.0rc1
# - Development: 1.0.0.dev1
Contributing
We welcome contributions! See Contributing Guide for:
- Development setup
- Code style guidelines
- Commit conventions
- Pull request process
Support
- Documentation: API Reference
- Issues: GitHub Issues
- Discussions: GitHub Discussions
License
Python source code: MIT (see LICENSE) Bundled runtime: 7-Zip 7zz under its own licenses (LGPL v2.1 + unRAR; parts BSD). See THIRD_PARTY_NOTICES.md and licenses/7zip-LICENSE.txt.
Acknowledgments
Built on 7-Zip by Igor Pavlov.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file py7zz-1.1.3-py3-none-win_amd64.whl.
File metadata
- Download URL: py7zz-1.1.3-py3-none-win_amd64.whl
- Upload date:
- Size: 1.2 MB
- Tags: Python 3, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bf20c9c4f76f9e1c84e2818e6078563a04014cabe6241e39b5d7ed20bbd51ef4
|
|
| MD5 |
410318ab2cdff8f5c9e0a3cf05159ce4
|
|
| BLAKE2b-256 |
4b36a31b87ac4b95749f9def6a43892f7c76133a251ad206ab5c7ed36b318e74
|
Provenance
The following attestation bundles were made for py7zz-1.1.3-py3-none-win_amd64.whl:
Publisher:
release.yml on RxChi1d/py7zz
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
py7zz-1.1.3-py3-none-win_amd64.whl -
Subject digest:
bf20c9c4f76f9e1c84e2818e6078563a04014cabe6241e39b5d7ed20bbd51ef4 - Sigstore transparency entry: 953571490
- Sigstore integration time:
-
Permalink:
RxChi1d/py7zz@155a2d902bb3ae7cfcb09b43ed98841380605fb6 -
Branch / Tag:
refs/tags/v1.1.3 - Owner: https://github.com/RxChi1d
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@155a2d902bb3ae7cfcb09b43ed98841380605fb6 -
Trigger Event:
push
-
Statement type:
File details
Details for the file py7zz-1.1.3-py3-none-manylinux1_x86_64.whl.
File metadata
- Download URL: py7zz-1.1.3-py3-none-manylinux1_x86_64.whl
- Upload date:
- Size: 1.4 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b03ec79e77240d15788985a1572ded828b751cb06af432e158f38c67df2fd7e
|
|
| MD5 |
36f7eb2a6585b58f1bc970bd4f803bd5
|
|
| BLAKE2b-256 |
91ba8486c5fb0f9c00cf3840af34900fa771c490357e1e50ddafd601976797f8
|
Provenance
The following attestation bundles were made for py7zz-1.1.3-py3-none-manylinux1_x86_64.whl:
Publisher:
release.yml on RxChi1d/py7zz
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
py7zz-1.1.3-py3-none-manylinux1_x86_64.whl -
Subject digest:
4b03ec79e77240d15788985a1572ded828b751cb06af432e158f38c67df2fd7e - Sigstore transparency entry: 953571488
- Sigstore integration time:
-
Permalink:
RxChi1d/py7zz@155a2d902bb3ae7cfcb09b43ed98841380605fb6 -
Branch / Tag:
refs/tags/v1.1.3 - Owner: https://github.com/RxChi1d
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@155a2d902bb3ae7cfcb09b43ed98841380605fb6 -
Trigger Event:
push
-
Statement type:
File details
Details for the file py7zz-1.1.3-py3-none-macosx_10_9_universal2.whl.
File metadata
- Download URL: py7zz-1.1.3-py3-none-macosx_10_9_universal2.whl
- Upload date:
- Size: 2.7 MB
- Tags: Python 3, macOS 10.9+ universal2 (ARM64, x86-64)
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
147b869cd632fe26b8450dbab293b36c4f55aa73d928639704c30764e20715d9
|
|
| MD5 |
dfbce0127985ca1205d30af2e5f9ca29
|
|
| BLAKE2b-256 |
f78102fe712129432c020ea962b87bb4c29400b315173ae332c9471e814f7580
|
Provenance
The following attestation bundles were made for py7zz-1.1.3-py3-none-macosx_10_9_universal2.whl:
Publisher:
release.yml on RxChi1d/py7zz
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
py7zz-1.1.3-py3-none-macosx_10_9_universal2.whl -
Subject digest:
147b869cd632fe26b8450dbab293b36c4f55aa73d928639704c30764e20715d9 - Sigstore transparency entry: 953571493
- Sigstore integration time:
-
Permalink:
RxChi1d/py7zz@155a2d902bb3ae7cfcb09b43ed98841380605fb6 -
Branch / Tag:
refs/tags/v1.1.3 - Owner: https://github.com/RxChi1d
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@155a2d902bb3ae7cfcb09b43ed98841380605fb6 -
Trigger Event:
push
-
Statement type: