AI-powered file organizer for macOS. Sorts by purpose, not file type.
Project description
TidyDesk
AI-powered file organizer for macOS. Sorts by purpose, not file type.
The Problem
Your Desktop and Downloads are dumping grounds. Existing tools sort by file type — screenshots here, PDFs there. But a screenshot of a Stripe dashboard belongs in finances/, not screenshots/. A PDF of a contract belongs in client-project/, not documents/.
TidyDesk reads your files (OCR on images, text from PDFs and code) and sorts them by what they're actually about.
Install
pip install tidydesk
Requires macOS and Python 3.10+. Bring your own Anthropic API key.
Quick Start
# 1. Configure (API key, folders, model)
tidydesk setup
# 2. Organize your files
tidydesk run
# 3. Don't like the result? Undo it
tidydesk undo
How It Works
- Scan — Collects files from your Desktop and Downloads (skips recent files, in-progress downloads, and hidden files)
- Extract — OCRs screenshots, reads PDF text, scans code/text files
- Classify — Sends file metadata + content to Claude, which assigns each file to a project folder by purpose
- Move — Creates folders and moves files. Every move is logged so you can undo.
Commands
| Command | Description |
|---|---|
tidydesk setup |
Configure API key, watch folders, and model |
tidydesk run |
Organize files now |
tidydesk run --dry-run |
Preview what would happen without moving anything |
tidydesk undo |
Reverse the last run |
tidydesk install |
Set up daily auto-run via launchd |
tidydesk uninstall |
Remove the daily schedule |
tidydesk status |
Show configuration and last run info |
Configuration
Stored at ~/.tidydesk/config.json:
| Field | Default | Description |
|---|---|---|
api_key |
— | Your Anthropic API key (required) |
watch_folders |
~/Desktop, ~/Downloads |
Folders to scan for files |
organize_to |
~/Desktop |
Where organized folders are created |
model |
claude-haiku-4-5-20251001 |
Claude model (Haiku or Sonnet) |
schedule_hour |
9 |
Hour for daily auto-run (0-23) |
schedule_minute |
0 |
Minute for daily auto-run (0-59) |
min_age_minutes |
60 |
Skip files newer than this |
batch_size |
25 |
Files per API call |
max_content_chars |
2000 |
Content extraction limit per file |
context_folders |
[] |
Paths to scan for project context (e.g. Obsidian vaults) |
Cost Estimate
TidyDesk uses your own API key. Estimated costs:
| Files/Day | Model | Daily Cost | Monthly Cost |
|---|---|---|---|
| 10 | Haiku | $0.002 | $0.06 |
| 25 | Haiku | $0.005 | $0.15 |
| 50 | Haiku | $0.010 | $0.30 |
| 25 | Sonnet | $0.05 | $1.50 |
FAQ
Is it safe?
Every move is logged to ~/.tidydesk/manifest.jsonl. Run tidydesk undo to reverse any run. Use --dry-run to preview first.
Does it read my files? Yes — that's how it works. File content is sent to the Claude API for classification. No data is stored or logged beyond the move manifest. TidyDesk has no telemetry, no accounts, and no phone-home behavior.
What model should I use?
Haiku is the default — fast, cheap, and good enough for most files. Switch to Sonnet (tidydesk setup → option 2) for better accuracy on ambiguous files.
Can I point it at project folders for context?
Yes. Set context_folders in config to paths like your Obsidian vault or project directories. TidyDesk will scan folder names to improve classification.
Does it work on Linux/Windows? No. macOS only — it uses the Vision framework for OCR and launchd for scheduling.
License
MIT
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 tidydesk-0.1.0.tar.gz.
File metadata
- Download URL: tidydesk-0.1.0.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9bea15cf299c391e5a8c2c09f07b5aa650458347ddb964a8c337718e6837d7cc
|
|
| MD5 |
d492c00b0abc73884cf0fe52f20fef8a
|
|
| BLAKE2b-256 |
0f15ab416cf7310adc206f278c66039fbc6a8714c045914b0124a2adb4b2ccf8
|
File details
Details for the file tidydesk-0.1.0-py3-none-any.whl.
File metadata
- Download URL: tidydesk-0.1.0-py3-none-any.whl
- Upload date:
- Size: 16.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a533456be90777deb1ab99d5d81500843ddfc451d11b5253ebfbefec58195342
|
|
| MD5 |
ac8f78705cc7a92e5dc614201e93aaa8
|
|
| BLAKE2b-256 |
8419fe61fae98e2e87a589813cba3b22930607e5e911403c6362fb80859e4e46
|