Skip to main content

A comprehensive collection of Python automation tools

Project description

Swiss Knife

Swiss Knife Logo
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 secrets module 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

swiss_knife_py-0.1.0b0.tar.gz (23.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

swiss_knife_py-0.1.0b0-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

Details for the file swiss_knife_py-0.1.0b0.tar.gz.

File metadata

  • Download URL: swiss_knife_py-0.1.0b0.tar.gz
  • Upload date:
  • Size: 23.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for swiss_knife_py-0.1.0b0.tar.gz
Algorithm Hash digest
SHA256 0e8f4983a5c7d25a314ac221cf014a6e85628d37b66ce9a07274b2724339c5c4
MD5 01083c649c71c1abcb6a0fb96e5b0098
BLAKE2b-256 30befc3b9e2c6a77099123d8b2483e95888bd14c8e494fff4d94a1f103e399df

See more details on using hashes here.

File details

Details for the file swiss_knife_py-0.1.0b0-py3-none-any.whl.

File metadata

File hashes

Hashes for swiss_knife_py-0.1.0b0-py3-none-any.whl
Algorithm Hash digest
SHA256 32fa0453839d1308fb929b76fecbc2293d4ae7d59a614718a517c3f7ab5a0bd5
MD5 78cc8e80d0eb541cc6f36c7ccafdee45
BLAKE2b-256 07ca535d6221cfe809cfa61f112f2a3050c2bb23c0ecab45fa8982b4f0b23923

See more details on using hashes here.

Supported by

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