This application utilizes Large Language Models (LLM) and FFmpeg to automate video editing tasks based on user instructions. Built with a Tkinter GUI, the tool offers a seamless and efficient way to edit videos with natural language commands.
- Intuitive GUI: Simple and user-friendly interface for video selection and instruction input.
- Advanced FFmpeg Command Generation: Automatically generates FFmpeg commands from user-provided instructions.
- Real-time Progress Tracking: Displays processing progress and status updates.
- Detailed Output Logging: Logs FFmpeg command execution and results.
- Clone the repository:
git clone https://github.com/sanskar9999/llm_video_editor.git cd llm_video_editor
- Install the required dependencies:
pip install tkinter subprocess re groq
- Run the application:
python llm_video_editor.py
- Open the application.
- Use the 'Browse' button to select a video file.
- Enter your editing instructions in natural english language in the text box.
- Click 'Process Video' to start the editing process.
- Monitor the progress and view the output logs within the application.
- "Convert video to black and white"
- "Add subtitles from file subs.srt"
- "Trim the video to the first 30 seconds"
- Error handling: Add more robust error handling, especially around the FFmpeg execution. Catch and display specific errors that may occur.
- Input validation: Add checks to ensure the video file exists and is a valid format before processing.
- Command preview: Allow users to preview and optionally edit the generated FFmpeg command before execution.
- Multiple operations: Support chaining multiple editing operations in a single session.
- Save/load instructions: Add functionality to save and load editing instruction presets.
- Progress tracking: Implement more detailed progress tracking for long-running operations.
- Undo functionality: Allow users to undo the last operation or revert to the original video.
- Video preview: Add a basic video player to preview the input and output videos.
- Batch processing: Support processing multiple videos with the same instructions.
- Custom output naming: Allow users to specify custom output file names.
- Settings: Add a settings menu to configure API keys, default folders, etc.
- Help/Documentation: Include a help section explaining how to use the app and common editing tasks.
- Logging: Implement logging to help with debugging and tracking usage.
- Multithreading improvements: Consider using a thread pool for better resource management.
- GUI improvements: Add tooltips, keyboard shortcuts, and improve the overall layout and styling.
This project is licensed under the MIT License. See the LICENSE file for details.
Contributions are welcome! Please open an issue or submit a pull request for any changes or improvements.