A comprehensive collection of Python automation tools
Project description
Swiss Knife
A Python automation toolkit for file management, text processing, and security utilities.
Swiss Knife is a Python package that provides essential automation tools with a focus on safety, security, and ease of use.
Features
File Management
- Duplicate Detection: Find and remove duplicate files using cryptographic hashes (MD5, SHA1, SHA256, SHA512)
- Bulk Renaming: Rename files in bulk using regex patterns with safety checks and dry-run mode
Text Processing
- CSV Conversion: Convert CSV files to JSON/XML with intelligent type inference and validation
Security & Automation
- Password Generation: Generate secure passwords with customizable policies and strength analysis
Quick Start
Installation
# Basic installation
pip install swiss-knife-py
# With XML processing support (recommended for security)
pip install swiss-knife-py[xml]
# With development tools
pip install swiss-knife-py[dev]
Command Line Usage
# Find duplicate files
sk-duplicates ~/Documents --algorithm sha256 --min-size 1MB
# Convert CSV to JSON
sk-csv data.csv --format json --output data.json --pretty
# Generate secure password
sk-password --length 16 --exclude-ambiguous
# Bulk rename files
sk-rename 'IMG_(\d+)' 'photo_\1' ~/Pictures --dry-run
Python API Usage
from swiss_knife.file_management.duplicate_finder import find_duplicates
from swiss_knife.file_management.bulk_renamer import bulk_rename
from swiss_knife.text_processing.csv_converter import convert_csv
from swiss_knife.automation.password_generator import generate_password
# Find duplicates
duplicates = find_duplicates(["/path/to/search"], algorithm="sha256")
print(f"Found {len(duplicates)} duplicate groups")
# Convert CSV to JSON
convert_csv("data.csv", "json", output_path="data.json", pretty=True)
# Generate secure password
password = generate_password(length=16, include_symbols=True)
print(f"Generated password: {password}")
# Bulk rename with safety checks
renamed_count = bulk_rename(r"IMG_(\d+)", r"photo_\1", "/path/to/images", dry_run=True)
Security Features
Swiss Knife prioritizes security with multiple safety mechanisms:
- Safe Defaults: All destructive operations require explicit confirmation
- Input Validation: Comprehensive validation prevents injection attacks
- Path Safety: Protection against path traversal vulnerabilities
- Memory Limits: Configurable limits prevent memory exhaustion
- Dry Run Mode: Test operations before executing them
- Cryptographic Security: Uses
secretsmodule for secure randomness
Development
# Clone the repository
git clone https://github.com/ayoub3bidi/swiss-knife.git
cd swiss-knife
# Install in development mode
pip install -e .[dev,all]
# Run tests
pytest
# Run linting
ruff check swiss_knife/
# Run security checks
bandit -r swiss_knife/
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 Distribution
Built Distribution
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 swiss_knife_py-0.1.0b1.tar.gz.
File metadata
- Download URL: swiss_knife_py-0.1.0b1.tar.gz
- Upload date:
- Size: 23.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
babecdfa166f661e0bd9f03b69c9557fe971a3b78a0991bd63d047e8f03b7d81
|
|
| MD5 |
c3da1ac0d839eb49d31a26159711b4ba
|
|
| BLAKE2b-256 |
d8d63d69dccdeccc2cb228643de8e50b9bc06df51bfec0daed504be99a309a9a
|
Provenance
The following attestation bundles were made for swiss_knife_py-0.1.0b1.tar.gz:
Publisher:
release.yml on ayoub3bidi/swiss-knife
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
swiss_knife_py-0.1.0b1.tar.gz -
Subject digest:
babecdfa166f661e0bd9f03b69c9557fe971a3b78a0991bd63d047e8f03b7d81 - Sigstore transparency entry: 718393778
- Sigstore integration time:
-
Permalink:
ayoub3bidi/swiss-knife@560523abee5fd1998a5c54e272bd38203eff919d -
Branch / Tag:
refs/tags/v0.1.0-beta - Owner: https://github.com/ayoub3bidi
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@560523abee5fd1998a5c54e272bd38203eff919d -
Trigger Event:
push
-
Statement type:
File details
Details for the file swiss_knife_py-0.1.0b1-py3-none-any.whl.
File metadata
- Download URL: swiss_knife_py-0.1.0b1-py3-none-any.whl
- Upload date:
- Size: 17.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1a20b753d6db1bd4fab647977a800eb30c56255548eef36d433a7c64b3ec7789
|
|
| MD5 |
00d0dcaf9a1f0a2c3798974f1b921759
|
|
| BLAKE2b-256 |
a758de867312231c85e0792d37af812ba5ca92427300a398b389bd200d5704b4
|
Provenance
The following attestation bundles were made for swiss_knife_py-0.1.0b1-py3-none-any.whl:
Publisher:
release.yml on ayoub3bidi/swiss-knife
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
swiss_knife_py-0.1.0b1-py3-none-any.whl -
Subject digest:
1a20b753d6db1bd4fab647977a800eb30c56255548eef36d433a7c64b3ec7789 - Sigstore transparency entry: 718393780
- Sigstore integration time:
-
Permalink:
ayoub3bidi/swiss-knife@560523abee5fd1998a5c54e272bd38203eff919d -
Branch / Tag:
refs/tags/v0.1.0-beta - Owner: https://github.com/ayoub3bidi
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@560523abee5fd1998a5c54e272bd38203eff919d -
Trigger Event:
push
-
Statement type: