A collection of file manipulation and inspection utilities, including pattern-based file operations.
Project description
Filesmith
A collection of file manipulation and inspection utilities, including pattern-based file operations and knapsack-based file selection.
Installation
You can install filesmith using pip:
pip install filesmith
Usage (CLI)
Filesmith provides a unified CLI with subcommands.
filesmith <command> [arguments] [options]
1. find-move
Find files and copy/move them.
filesmith find-move <src> <dst> [-p PATTERN] [-m {copy,move}] [-n] [-R]
src: Source directory.dst: Destination directory.-p,--pattern: Glob pattern (default:*).-m,--mode:copyormove(default:copy).-n,--dry-run: Show what would be done.-R,--no-recursive: Do NOT search recursively.
Example:
filesmith find-move ./src ./backup -p "*.py"
2. knapsack
Knapsack-related operations.
copy
Copy a subset of files to a destination without exceeding a total size capacity.
filesmith knapsack copy <src_dir> <dest_dir> <capacity> [-p PATTERN] [-n] [-R]
Example:
# Copy up to 100MB of images
filesmith knapsack copy ./photos ./usb-drive 104857600 -p "*.jpg"
solve
Solve a general knapsack/subset-sum problem for integer items.
filesmith knapsack solve <capacity> <items...>
3. Legacy CLI
The original regex-based copy tool is available via:
filesmith-legacy copy <origin> <destination> <pattern> [--newermt REF] [-n] [-q]
Python API
Filesmith can also be used as a Python library.
File Operations
find_files & transfer_files
Modern, structured way to find and move/copy files.
from pathlib import Path
from filesmith import find_files, transfer_files
# Find all Python files recursively
files = find_files(Path("./src"), pattern="*.py", recursive=True)
# Transfer them to a backup folder (copy or move)
transfer_files(files, Path("./backup"), mode="copy", on_conflict="skip")
FindMoveJob
An orchestration class for "find and transfer" operations.
from pathlib import Path
from filesmith import FindMoveJob
job = FindMoveJob(
src_root=Path("./src"),
dest_root=Path("./dst"),
pattern="*.txt",
mode="move"
)
job.run()
get_target_file
Finds exactly one file in a directory that matches a key and optional extension. Throws ValueError if zero or multiple files are found.
from filesmith import get_target_file
# Returns a Path object if unique match found
path = get_target_file("./data", "report_2023", ext=".csv")
print(f"Found unique report: {path.name}")
copy_files (Legacy)
Regex-based copy tool with optional modification time filtering.
from filesmith import copy_files
# Copy files matching a regex, newer than a specific date
copy_files(
origin="./logs",
destination="./archive",
pattern=r"error_.*\.log",
newermt="2023-01-01"
)
Optimization & Knapsack
copy_files_by_capacity
Copies a subset of files that fit within a specified byte capacity. Useful for filling external drives.
from filesmith import copy_files_by_capacity
total_size, ops = copy_files_by_capacity(
src_dir="./photos",
dest_dir="/mnt/usb",
capacity=1024 * 1024 * 700 # 700 MB
)
print(f"Filled {total_size} bytes across {len(ops)} files.")
run_knapsack
General-purpose subset-sum solver for integer items.
from filesmith import run_knapsack
items = [10, 20, 30, 40, 50]
capacity = 65
best_sum, indices = run_knapsack(items, capacity)
# best_sum: 60, indices: [4, 0] (50 + 10) or similar
Changelog
0.4.1
- Enriched Python API documentation with practical usage examples.
0.4.0
- Added unified
filesmithcommand with subcommands:find-move,knapsack. - Added
filesmith-legacyfor the previous regex-based CLI. - Expanded Python API in
filesmithpackage. - Improved internal structure (finder, transfer, engine).
0.2.0
- Added
get_target_fileutility. - Improved
copy_fileswith structured logging and--newermtfiltering.
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
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 filesmith-0.4.1.tar.gz.
File metadata
- Download URL: filesmith-0.4.1.tar.gz
- Upload date:
- Size: 17.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f16640682360533bf201bc321a5b302afeb8f238a30ca51107fa714f790d0321
|
|
| MD5 |
5ae20f40c4b0bca0857f902a770807e6
|
|
| BLAKE2b-256 |
14d7ada991ef470e82777af4cb8be851bbab2d532401735e29b56b7e95e643f8
|
File details
Details for the file filesmith-0.4.1-py3-none-any.whl.
File metadata
- Download URL: filesmith-0.4.1-py3-none-any.whl
- Upload date:
- Size: 13.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
974802a0adf2f3b40c11421aceff7007acec9bbe16ef501974527456ffca1872
|
|
| MD5 |
bb3081aa8eea8d763c0c66f67f57cf20
|
|
| BLAKE2b-256 |
05104def7bbbccebab951ea4e27af80134d3dbb4b1cc34a0c069cae1b6d32ecb
|