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.0b2.tar.gz (23.5 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.0b2-py3-none-any.whl (17.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: swiss_knife_py-0.1.0b2.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

Hashes for swiss_knife_py-0.1.0b2.tar.gz
Algorithm Hash digest
SHA256 8b86b312982274d1d7366b0ec7f2309b3ff6e0d8fd6aa0c935a8ce61dca4f95d
MD5 f89be00891384499f2b08c2d034a9620
BLAKE2b-256 1cfffd7f7ebbed71e8e3aa4f0c36d9769e19b0d20816c97a09f5b39c122ec343

See more details on using hashes here.

Provenance

The following attestation bundles were made for swiss_knife_py-0.1.0b2.tar.gz:

Publisher: release.yml on ayoub3bidi/swiss-knife

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

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

File metadata

File hashes

Hashes for swiss_knife_py-0.1.0b2-py3-none-any.whl
Algorithm Hash digest
SHA256 2b8f2795ae962b4c429f6c2c50c10be5840be8d4163bb63a33d47997ea22fb2c
MD5 3400c90e8cb9d4149532c665ef3178be
BLAKE2b-256 e8e4837b5e697cae33fbe65e56144f402abfc1e41fecc0842d18d53d5a7f9fa6

See more details on using hashes here.

Provenance

The following attestation bundles were made for swiss_knife_py-0.1.0b2-py3-none-any.whl:

Publisher: release.yml on ayoub3bidi/swiss-knife

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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