Skip to main content

A Python CLI utility to organize your Downloads folder by extension

Project description

Pikapika — Downloads Folder Organizer

Automatically organize your files by extension with one command

Pikapika Logo

Python 3.13 MIT License uv compatible Downloads GitHub Stars

📚 View Documentation | 🐍 PyPI Package | 🐛 Report Issues

Pika Pika (ピカピカ)” is an onomatopoeia in Japanese, meaning “shiny” or “sparkly”. This project is mainly used to clean your folders of clutter and manage them efficiently. It automatically files items into category folders (Images, Documents, Archives, Installers, etc.) and optionally quarantines junk files such as partial downloads.

Built with Python 3.13 and the uv workflow.


Features

  • Dry run mode (--dry-run) shows every planned move before mutating files.
  • Category routing using an editable extension map in src/pikapika/__init__.py.
  • Junk handling for extensions like .crdownload, .tmp, .part: quarantine them or send them to the Recycle Bin (via send2trash).
  • Duplicate safety — automatically renames conflicts (file (1).pdf).
  • Recursive mode to organize nested folders while skipping known system directories (.git, __pycache__, etc.).

Requirements

  • Python 3.13+
  • uv for dependency and virtualenv management

Optional:

  • send2trash (installed automatically) if you want junk files to go to the system trash instead of _Quarantine.

Installation

git clone https://github.com/arizmuajianisan/pikapika.git
cd pikapika
uv sync --group dev        # installs runtime + dev dependencies

Useful helpers are available via make:

make help
# test, check, format, run, clean, ...

If you prefer plain commands:

uv run pytest              # run tests
uv run ruff check          # lint
uv run ruff format         # format
uv run pikapika --dry-run  # execute CLI

Usage

Run commands from the project root (or install the package and use the pikapika entry point globally).

uv run pikapika --help

Common flags

Flag Description
--path PATH Downloads directory to organize. Defaults to the current user's Downloads.
--dry-run Print intended operations without touching the filesystem.
--recursive Walk subdirectories (skips known system folders automatically).
--quarantine-junk Move old junk files to _Quarantine.
--junk-days N Minimum age (days) for junk files before action (default: 7).
--trash-junk Send junk files to the OS trash (requires send2trash).

Examples

# Preview current user's Downloads
uv run pikapika --dry-run

# Organize a specific folder for real
uv run pikapika --path "D:\Downloads" 

# Go recursive and quarantine stale junk (>= 10 days old)
uv run pikapika --recursive --quarantine-junk --junk-days 10

# Send junk to Recycle Bin instead of _Quarantine
uv run pikapika --quarantine-junk --trash-junk

Customizing categories

Edit the CATEGORIES dictionary in src/pikapika/__init__.py:

CATEGORIES = {
    "Images": {".png", ".jpg", ".svg"},
    "Documents": {".pdf", ".docx", ".md"},
    "Archives": {".zip", ".iso"},
}

Add or rename folders, or introduce new buckets (e.g., "DesignAssets", "DiskImages"). Always run with --dry-run after changes to verify they behave as expected.


Development workflow

uv sync --group dev   # install everything
make check            # lint (ruff)
make format           # format (ruff fmt)
make test             # run pytest suite
make run              # run CLI in-place

The test suite (tests/test_pikapika.py) covers:

  • extension categorization
  • duplicate handling
  • junk quarantine/trash flow
  • recursive traversal and skip logic

Release Process

This project uses automated releases via GitHub Actions, similar to release-it for JavaScript projects.

Quick Release (Recommended)

# Patch release (bug fixes)
make release-patch

# Minor release (new features)
make release-minor

# Major release (breaking changes)
make release-major

Manual Release Steps

# 1. Run the release script
uv run python scripts/release.py patch

# 2. The script will:
#    - Check git status is clean
#    - Run tests and linting
#    - Update version in pyproject.toml
#    - Build package
#    - Create and push git tag (e.g., v0.1.1)

# 3. GitHub Actions will automatically:
#    - Run comprehensive tests
#    - Build and validate package
#    - Publish to TestPyPI
#    - Verify TestPyPI installation
#    - Publish to production PyPI
#    - Create GitHub Release with changelog

Dry Run Mode

# Preview what would happen without making changes
uv run python scripts/release.py patch --dry-run

Release Workflow Details

  • Trigger: Git tags starting with v (e.g., v0.1.0, v1.2.3)
  • Testing: Multi-platform tests (Ubuntu, Windows, macOS)
  • Publishing: TestPyPI → PyPI (with verification)
  • Release Notes: Auto-generated changelog from git commits
  • Badges: Updated automatically after release

Troubleshooting

  • Hardlink warning during uv sync
    Set UV_LINK_MODE=copy (or run with uv sync --link-mode=copy) when working across filesystems that do not support hardlinks.

  • --trash-junk no-ops
    Ensure send2trash is installed (it is pulled in automatically when using uv sync --group dev). On Windows you might need to reopen the shell after installation.

  • Downloads path seems wrong
    Supply an explicit path with --path when using redirected or network-backed folders.


License

MIT — see the LICENSE file for details. Feel free to fork, tweak, and ship improvements. Contributions welcome!

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

pikapika_organizer-0.3.0.tar.gz (10.6 kB view details)

Uploaded Source

Built Distribution

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

pikapika_organizer-0.3.0-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file pikapika_organizer-0.3.0.tar.gz.

File metadata

  • Download URL: pikapika_organizer-0.3.0.tar.gz
  • Upload date:
  • Size: 10.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pikapika_organizer-0.3.0.tar.gz
Algorithm Hash digest
SHA256 62a2fc5dbf28aef07c1f0f398e0cc54ab360404ab7504f2fbc20f3e92e10b41e
MD5 1593dfbd1cbfccbdd78306920776c998
BLAKE2b-256 9f450e68a20ce5b357242ae4157e011467e9e76f3726dd01a4549a6f062ad4bc

See more details on using hashes here.

File details

Details for the file pikapika_organizer-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pikapika_organizer-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b2d1df34f78eb34f912e47ba3921e69014ce206b4000f7e4a678c48a9193a940
MD5 ed1ce371a45fb2845639cd75bce2555a
BLAKE2b-256 37fbf012623f7ad990673b54a85f6bf7cb63ab1f4a6e1d26300ecc49fc960733

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