tzst Documentation
Welcome to tzst, the next-generation Python library engineered for modern archive management, leveraging cutting-edge Zstandard compression to deliver superior performance, security, and reliability.
What is tzst?
tzst is a modern Python library built exclusively for Python 3.12+ that provides comprehensive support for creating, extracting, and managing .tzst and .tar.zst archives. It combines the proven reliability of the tar format with the superior compression efficiency of Zstandard (zstd) to deliver:
Superior Performance: Fast compression and decompression with excellent compression ratios
Enterprise-Grade Security: Safe extraction with built-in protections against path traversal attacks
Memory Efficiency: Streaming mode for handling large archives with minimal memory usage
Cross-Platform Compatibility: Works seamlessly on Windows, macOS, and Linux
Developer-Friendly: Clean, Pythonic API with comprehensive error handling
Key Features
Advanced Compression
Zstandard Compression: Best-in-class compression algorithm with configurable levels (1-22)
Multiple Extensions: Support for both
.tzstand.tar.zstfile extensionsStreaming Support: Memory-efficient processing for large archives
Security First
Safe by Default: Uses ‘data’ filter for secure extraction without dangerous path traversal
Multiple Filter Options: Choose from ‘data’, ‘tar’, or ‘fully_trusted’ filters based on your security needs
Atomic Operations: All file operations use temporary files with atomic moves to prevent corruption
Dual Interfaces
Command Line: Intuitive CLI with comprehensive options for batch operations
Python API: Clean, object-oriented interface for programmatic use
Convenience Functions: High-level functions for common operations
High Performance
Optimized I/O: Efficient buffering and streaming for large files
Conflict Resolution: Intelligent handling of file conflicts during extraction
Cross-Platform: Native performance on all major operating systems
Quick Example
from tzst import TzstArchive, create_archive, extract_archive
# Create an archive
create_archive("backup.tzst", ["documents/", "photos/"], compression_level=5)
# Extract an archive
extract_archive("backup.tzst", "restore/")
# Work with archives programmatically
with TzstArchive("data.tzst", "r") as archive:
contents = archive.list(verbose=True)
archive.extract("important.txt", "output/")
is_valid = archive.test()
Installation
For detailed installation instructions, including standalone binaries and source installation, please refer to the Quick Start Guide guide.
# Install from PyPI
pip install tzst
# Or using uv (recommended)
uv tool install tzst
Getting Started
For a quick introduction, see the Quick Start Guide guide. For comprehensive usage examples, explore the Examples section.
API Documentation
Complete API documentation is available in the API Reference section, covering:
Core API: Main classes and functions
CLI API: Command-line interface
Exceptions API: Error handling
Development
For comprehensive development information, see the Development Guide guide, which covers:
Setting up development environment
Running tests and code quality checks
Documentation building
Contributing workflow and guidelines
Project structure and best practices
Quick Start
git clone https://github.com/xixu-me/tzst.git
cd tzst
pip install -e .[dev]
pytest
Contributing
We welcome contributions! Please read our Contributing Guide for:
Development setup and project structure
Code style guidelines and best practices
Testing requirements and writing tests
Pull request process and review workflow
Types of Contributions Welcome
Bug fixes - Fix issues in existing functionality
Features - Add new capabilities to the library
Documentation - Improve or add documentation
Tests - Add or improve test coverage
Performance - Optimize existing code
Security - Address security vulnerabilities
Acknowledgments
Meta Zstandard for the excellent compression algorithm
python-zstandard for Python bindings
The Python community for inspiration and feedback
License
Copyright © Xi Xu. All rights reserved.
Licensed under the BSD 3-Clause license.
Documentation Guide
Quick Start Guide - Get up and running quickly with basic examples
Performance Guide - Performance optimization guide and comparisons
Examples - Comprehensive usage examples and patterns
API Reference - Complete API reference documentation
Development Guide - Development and contribution guidelines
Index - Index of all documented items
Requirements
Python 3.12 or higher (tested on 3.12-3.14)
zstandard >= 0.19.0