Python API for AviUtl ver.2 project files (.aup2)
Project description
AviUtl2 Project API
Python API for manipulating AviUtl ver.2 project files (.aup2).
Overview
AviUtl ver.2 uses a text-based project format (.aup2) similar to INI files. This library provides:
- Parser: Read .aup2 files into Python objects
- Serializer: Write Python objects back to .aup2 format
- JSON Conversion: Export/import as JSON for LLM processing
- Validation: Timeline collision detection and frame calculations
- CLI Tool: Command-line interface for AI agent automation
- Preset System: Save and reuse animation/effect combinations
- Frame Preview: Render frames to PNG for Vision AI verification
- Smart Automation: Auto frame range, layer selection, and media duration detection
Installation
pip install aviutl2-api
CLI Quick Start
# Create new project
aviutl2 new project.aup2 --width 1920 --height 1080 --fps 30
# Add objects (frame range is optional - defaults to 60 frames, auto-appends)
aviutl2 add text project.aup2 "Hello World" # Auto: frames 0-59
aviutl2 add shape project.aup2 circle --duration 90 # Auto: frames 60-149
aviutl2 add text project.aup2 "Manual" --from 0 --to 90 # Manual: frames 0-90
# View timeline
aviutl2 timeline project.aup2
# Apply preset
aviutl2 preset init # Initialize sample presets
aviutl2 preset apply project.aup2 0 fade-in # Apply preset to object
# Preview frame (for Vision AI)
aviutl2 preview project.aup2 --frame 0 -o preview.png
aviutl2 preview project.aup2 --frame 0 -o small.png --max-width 800 # Resized for API
# Add animation
aviutl2 animate project.aup2 0 opacity --start 0 --end 100 --motion smooth
# Add filter
aviutl2 filter add project.aup2 0 blur --strength 10
# Batch edit (regex filtering)
aviutl2 batch project.aup2 --filter-text "Hello.*" --color ff0000 # Change all "Hello" texts to red
aviutl2 batch project.aup2 --filter-layer "1-5" --opacity 50 # Set opacity for layers 1-5
# Fix collisions (auto-resolve layer conflicts)
aviutl2 fix project.aup2 # Detect and auto-fix collisions
aviutl2 fix project.aup2 --dry-run # Check only (no changes)
Python API
from aviutl2_api import parse_file, serialize_to_file, to_json
# Load project
project = parse_file("my_project.aup2")
# Access scenes and objects
scene = project.scenes[0]
for obj in scene.objects:
print(f"Layer {obj.layer}: frames {obj.frame_start}-{obj.frame_end}")
# Save project
serialize_to_file(project, "output.aup2")
# Export as JSON
json_data = to_json(project)
CLI Commands
Project Operations
| Command | Description |
|---|---|
new |
Create new project |
info |
Show project information |
timeline |
Display ASCII timeline |
preview |
Render frame to PNG for Vision AI |
layers |
List layers |
objects |
List objects |
search |
Search objects at frame |
range |
List objects in frame range |
check |
Check if placement is possible |
Object Operations
| Command | Description |
|---|---|
add text |
Add text object |
add shape |
Add shape object |
add audio |
Add audio file |
add video |
Add video file |
add image |
Add image file |
move |
Move object position |
delete |
Delete object |
copy |
Duplicate object |
modify |
Change object properties |
batch |
Batch edit with filters (regex) |
fix |
Auto-fix layer collisions |
Animation & Effects
| Command | Description |
|---|---|
animate |
Set animation on property |
filter add |
Add filter effect |
Preset System
| Command | Description |
|---|---|
preset list |
List available presets |
preset show |
Show preset details |
preset apply |
Apply preset to object |
preset save |
Save object settings as preset |
preset delete |
Delete preset |
preset init |
Initialize with sample presets |
JSON Conversion
| Command | Description |
|---|---|
export-json |
Export project to JSON |
import-json |
Import project from JSON |
Frame Preview (Vision AI Integration)
Render project frames to PNG images for verification by Vision-enabled LLMs.
# Render single frame
aviutl2 preview project.aup2 --frame 0 -o preview.png
# Resize for Vision AI (recommended to avoid API size limits)
aviutl2 preview project.aup2 --frame 0 -o small.png --max-width 800
aviutl2 preview project.aup2 --frame 0 -o small.png --max-height 600
aviutl2 preview project.aup2 --frame 0 -o half.png --scale 0.5
# Render filmstrip (multiple frames in one image)
aviutl2 preview project.aup2 --strip --interval 30 -o timeline.png
Resize Options
| Option | Description |
|---|---|
--max-width N |
Limit width to N pixels (maintains aspect ratio) |
--max-height N |
Limit height to N pixels (maintains aspect ratio) |
--scale X |
Scale factor (e.g., 0.5 for 50% size) |
Warnings: The tool automatically warns when:
- Aspect ratio would be changed
- Scale factor is below 50% (text/lines may become hard to read)
- Scale factor is below 25% (details may be lost)
Sample Presets
17 sample presets are included:
Animations:
spin-fade-out- Rotate 10 times while fading outfade-in,fade-out- Opacity transitionsslide-in-left,slide-in-right,slide-out-right- Slide animationsbounce-vertical,bounce-horizontal- Bounce effectszoom-in,zoom-out- Scale animationsspin-once- Single rotationorbit- Circular motion
Effects:
shake- Vibration effectglow-pulse- Glow effectblur-soft- Soft blurtext-shadow- Drop shadow for textborder-white- White border
Development
Setup
# Clone and setup
git clone https://github.com/Marble-GP/AviUtl2_API.git
cd AviUtl2_API
python -m venv .venv
# Activate virtual environment
# Linux/macOS/WSL:
source .venv/bin/activate
# Windows PowerShell:
.\.venv\Scripts\Activate.ps1
# Windows Command Prompt:
.\.venv\Scripts\activate.bat
# Install in editable mode
pip install -e ".[dev]"
Important: Always activate the virtual environment before running aviutl2 commands. Your prompt should show (.venv) when activated.
If you get a PowerShell execution policy error on Windows:
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
Testing and Linting
# Test
pytest
# Type check
mypy src/
# Lint
ruff check src/
Documentation
- CLI Manual - Detailed CLI documentation
- .aup2 Format Specification - File format details
License
MIT
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
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 aviutl2_api-0.1.4.tar.gz.
File metadata
- Download URL: aviutl2_api-0.1.4.tar.gz
- Upload date:
- Size: 88.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb7d893cf0af5b78087c5698c956a3f8afc64076d74299b86a315241e01c5a17
|
|
| MD5 |
d1e85b4d8ae3b0b9d29dbb9c2d4d8b7a
|
|
| BLAKE2b-256 |
d95f65d3623300bc27e72cf8bb420383f8d6bb0e9590deea7ccca975c8649220
|
File details
Details for the file aviutl2_api-0.1.4-py3-none-any.whl.
File metadata
- Download URL: aviutl2_api-0.1.4-py3-none-any.whl
- Upload date:
- Size: 75.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d61b2ae7693cae175eb826cdbbe81b669450ba733e63beca17fd5ddb642ba925
|
|
| MD5 |
2a69a4124b8ae93c1c46bf17374d0092
|
|
| BLAKE2b-256 |
9cf0ef2e9a26721957b10816b4f11c964696364ed285d5bbd4115ae406d69603
|