An intelligent file organization tool that uses AI to automatically categorize and organize your files. Works on macOS, Linux (Ubuntu, etc.), and Windows.
Name was inspired by the music I was listening to when this idea popped in my head, the music is Organize by Asake
- 🤖 AI-Powered Categorization: Uses OpenAI's GPT to intelligently categorize files based on content and metadata
- 📂 Multiple Directory Support: Organizes common directories (Documents, Desktop, Downloads, etc.)
- 🔒 Cross-Platform: Works on macOS, Linux (Ubuntu, etc.), and Windows
- 🔒 Permission Handling: Properly handles file access permissions across platforms
- 💾 Backup System: Creates automatic backups before moving files
- 🎯 Smart Organization: Groups files into logical categories (documents, images, videos, audio, etc.)
- 🖥️ Terminal Interface: Clean, user-friendly command-line interface
- 🔍 Dry Run Mode: Preview organization plan before making changes
Why uv? uv provides fast, reliable Python project management with automatic virtual environment creation, dependency resolution, and lockfile management. It's significantly faster than pip and handles all the complexity of Python environments for you.
First, install uv and ffmpeg:
macOS:
Linux:
Windows:
Alternative (PyPI):
For more installation options, see the official uv installation guide.
Then set up ai-rganize:
What uv does for you:
- 🚀 Automatic virtual environment creation (.venv/ directory)
- 📦 Dependency resolution and installation from pyproject.toml
- 🔒 Lockfile management (uv.lock) for reproducible builds
- ⚡ Fast package installation (10-100x faster than pip)
- 🛠️ Project management with uv sync, uv add, uv remove
- 🐍 Python version management with uv python install
-
Install dependencies:
pip install -r requirements.txt -
Get OpenAI API Key:
- Visit OpenAI Platform
- Create a new API key
- Add it to your environment or .env file
-
Set up permissions:
- macOS: System Preferences > Security & Privacy > Privacy
- Linux: Check file ownership and permissions
- Windows: Run as Administrator if needed
Basic commands:
Alternative: Using uv run (no activation needed):
Model selection and cost control:
Project management with uv:
- --api-key: OpenAI API key (or set OPENAI_API_KEY env var)
- --directory, -d: Specific directory to organize
- --dry-run: Show organization plan without moving files
- --backup/--no-backup: Create backup before organizing (default: backup)
- --ai-limit: Maximum number of files to analyze with AI (default: 50)
- --max-file-size: Maximum file size in MB for AI analysis (default: 10)
- --no-ai: Disable AI categorization, use only rule-based
Or create a .env file:
-
File Scanning: Scans target directories for files
-
AI Analysis: Uses OpenAI GPT to analyze file content and metadata
-
Categorization: Groups files into logical categories:
- 📄 Documents (PDFs, Word docs, text files)
- 🖼️ Images (photos, graphics, screenshots)
- 🎬 Videos (movie files, recordings)
- 🎵 Audio (music, podcasts, recordings)
- 📦 Archives (zip files, compressed files)
- 💻 Code (programming files)
- 📊 Spreadsheets (Excel, CSV files)
- 📽️ Presentations (PowerPoint, Keynote)
- 📁 Other (miscellaneous files)
-
Organization: Moves files to appropriate category folders
-
Logging: Records all changes for reference
- ✅ Automatic Backups: Creates timestamped backups before any changes
- ✅ Dry Run Mode: Preview changes before executing
- ✅ Permission Checks: Verifies access to directories
- ✅ Duplicate Handling: Prevents overwriting existing files
- ✅ Error Handling: Graceful handling of permission errors
- ✅ Logging: Complete audit trail of all changes
The tool organizes files into these categories:
| Documents | PDF, DOC, TXT, RTF | Reports, letters, manuals |
| Images | JPG, PNG, GIF, HEIC | Photos, screenshots, graphics |
| Videos | MP4, MOV, AVI, MKV | Movies, recordings, clips |
| Audio | MP3, WAV, FLAC, M4A | Music, podcasts, recordings |
| Archives | ZIP, RAR, 7Z, TAR | Compressed files, backups |
| Code | PY, JS, HTML, CSS | Programming files, scripts |
| Spreadsheets | XLS, CSV, NUMBERS | Data files, reports |
| Presentations | PPT, KEY | Slides, presentations |
Setup for development:
Development commands:
Contributing:
- Fork the repository
- Create a feature branch
- Make your changes
- Test: ai-rganize --dry-run
- Submit a pull request
The tool automatically skips files larger than 10MB for AI analysis to avoid high API costs. These files are categorized using rule-based methods.
- Backups are stored in ~/.ai-rganize_backup/
- Each backup is timestamped
- Organization logs are stored in ~/.ai-rganize_log.json
- Python 3.7+
- OpenAI API key
- Internet connection (for AI analysis)
- openai: AI categorization
- click: Command-line interface
- rich: Beautiful terminal output
- Pillow: Image file analysis
MIT License - feel free to use and modify!
Contributions welcome! Please feel free to submit issues and pull requests.
This tool moves and organizes your files. Always:
- Test with --dry-run first
- Keep backups enabled
- Review the organization plan before proceeding
- Use at your own risk
The AI categorization is based on file content analysis and may not be 100% accurate. Always review the results before proceeding with large-scale organization.
.png)

