File Organizer MCP
An intelligent MCP server that analyzes folder contents to automatically categorize files and suggest meaningful naming conventions based on file types and content. It enables users to organize messy directories into structured topic-based folders through automated analysis, renaming, and file movement tools.
README
File Organizer
A Python utility to analyze folders and suggest organized file structures using AI classification. The classifier can use OpenAI, a custom LLM endpoint, or interactive prompts.
Features
- Analyze a folder and suggest categories for files using AI.
- Subcategorize files with AI-determined categories (e.g., Python, Flask, PostgreSQL, etc.).
- Produce a suggested folder structure and AI-suggested filenames.
- Support for OpenAI, custom LLM endpoints, or interactive manual classification.
- Graceful fallback: when AI unavailable, optionally ask user for input via CLI/Inspector.
Quick start
Prerequisites: Python 3.9+ and pip.
Install dependencies:
python -m pip install -r requirements.txt
Run tests:
python -m pytest -q
Using the classifier
Option 1: OpenAI (recommended)
- Get an OpenAI API key from platform.openai.com.
- Run with AI:
$env:OPENAI_API_KEY = 'sk-your-key-here'
python main.py /path/to/folder
Option 2: Custom LLM endpoint
If you have a custom LLM service, configure it:
$env:EXTERNAL_LLM_URL = 'https://your-llm-api.example.com/classify'
$env:EXTERNAL_LLM_API_KEY = 'your-api-key'
python main.py /path/to/folder
Your endpoint should accept JSON:
{
"filename": "example.py",
"file_type": ".py",
"content_preview": "def hello(): ..."
}
And return JSON:
{
"category": "Code",
"confidence": 0.95,
"subcategory": "Python",
"suggested_name": "hello_world.py"
}
Option 3: Interactive mode (manual classification)
For testing or when you prefer to classify files manually:
$env:INTERACTIVE_MODE = 'true'
python main.py /path/to/folder
The system will prompt you for each file's category, confidence, subcategory, and suggested name.
Option 4: No AI (auto-categorizes as "Uncategorized")
python main.py /path/to/folder
All files will be categorized as "Uncategorized" without any AI or interactive prompts.
Project layout
services/— core services (FileAnalysisService,FileOrganizationService).models/— dataclasses forFileMetadata,FolderOrganization,OrganizationResult.tests/— unit tests (run withpytest).utils/— helpers and validators.
Contributing
- Fork the repo and create a branch for your feature/bugfix.
- Run tests and add new tests for your changes.
- Open a pull request describing the change.
License
This repository does not include a license file. Add one if you intend to publish or share the project publicly (e.g. MIT).
File Organizer MCP
An intelligent MCP (Model Context Protocol) server that analyzes folders, automatically categorizes files, suggests meaningful names, and organizes them into topic-based folder structures.
Features
- Folder Analysis: Scan a folder and analyze its contents
- Intelligent Categorization: Automatically categorize files by type (Documents, Images, Code, Data, etc.)
- Smart Naming: Suggest improved, meaningful filenames based on content and context
- Folder Organization: Create organized folder structures by topics
- File Organization: Option to move and rename files according to suggested structure
- Metadata Extraction: Extract tags and metadata from files for better organization
- Confidence Scoring: Get confidence scores for suggested categorizations
Installation
pip install -e .
Configuration
Edit settings.py to customize:
- Maximum file size to analyze
- File extensions to consider as text
- Category detection keywords
- Maximum folder name length
Usage
As an MCP Server
Start the server:
python main.py
Available Tools
1. analyze_folder
Analyze a folder to understand its contents and suggest organization.
Parameters:
folder_path(string, required): Absolute path to the folder to analyze
Returns:
- Suggested folder structure
- File categorization
- Renamed suggestions for each file
- Confidence scores
Example:
{
"folder_path": "/path/to/folder"
}
2. organize_files
Organize files into topic-based folders with suggested names.
Parameters:
folder_path(string, required): Absolute path to the folder to organizecreate_folders(boolean, optional): Whether to create the folder structure (default: false)move_files(boolean, optional): Whether to actually move files to new folders (default: false)apply_naming(boolean, optional): Whether to rename files with suggested names (default: false)
Returns:
- Created folders list
- Moved files list
- Any errors encountered
- Summary statistics
3. get_structure
Get the suggested folder structure for an analyzed folder.
Parameters:
folder_path(string, required): Absolute path to the folder
Returns:
- Suggested structure with categories and file counts
Project Structure
file-organizer-mcp/
├── main.py # MCP server entry point
├── settings.py # Configuration settings
├── pyproject.toml # Project metadata
├── requirements.txt # Python dependencies
├── README.md # This file
├── models/
│ ├── __init__.py
│ ├── result.py # OperationResult model
│ └── file_models.py # File and organization models
├── services/
│ ├── __init__.py
│ ├── file_analysis_service.py # File analysis logic
│ └── file_organization_service.py # File organization logic
├── utils/
│ ├── __init__.py
│ ├── errors.py # Custom exceptions
│ ├── paths.py # Path utilities
│ └── validate.py # Validation utilities
└── tests/
├── __init__.py
├── test_file_analysis_service.py
├── test_file_organization_service.py
└── test_integration.py
Categories
The server automatically recognizes and organizes into these categories:
- Documents: PDFs, Word docs, text files, reports
- Images: Photos, graphics, icons, screenshots
- Videos: Video files and recordings
- Audio: Music files, podcasts, audio recordings
- Code: Source code files in various languages
- Data: Datasets, databases, CSV, SQL files
- Configuration: Config files, settings, environment files
- Archives: Compressed files (zip, rar, etc.)
- Backup: Backup and old version files
- README: Documentation and guide files
Example Workflow
-
Analyze a folder:
result = analyze_folder("/path/to/messy/folder") -
Review the suggested structure
-
Organize with folders created but files not moved (safe preview):
organize_files("/path/to/messy/folder", create_folders=True, move_files=False) -
If satisfied, actually move files:
organize_files("/path/to/messy/folder", create_folders=True, move_files=True)
Testing
Run tests:
pytest tests/
Error Handling
The server provides detailed error handling:
InvalidPathError: When folder path is invalidFileAccessError: When files cannot be accessedAnalysisError: When file analysis failsOrganizationError: When organization fails
Limitations
- Maximum file size for analysis: 10 MB (configurable)
- Maximum files per folder: 1000 (configurable)
- Text file preview: First 500 characters only
- Folder name length: Maximum 200 characters
Contributing
Feel free to submit issues and enhancement requests!
License
MIT License
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.