Skip to content

Command-line utility for batch-managing default audio and subtitle tracks in MKV files.

License

Notifications You must be signed in to change notification settings

RatzzFatzz/MKVAudioSubtitleChanger

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduction

A streamlined solution for managing MKV files, this program leverages MKVToolNix to modify audio and subtitle track properties without the need for time-consuming file reencoding. Users can easily set their track preferences, and the application intelligently applies the best matching configuration. The tool focuses on metadata modification rather than full file rewriting, ensuring quick operations while maintaining the original file integrity. This makes it an ideal choice for managing multilingual media collections or batch processing multiple MKV files.

Requirements

  • Java 21 or newer
  • mkvtoolnix installation

Execution

Minimal usage

Portable: java -jar mkvaudiosubtitlechanger-<version>.jar --library "X:/Files" --attribute-config eng:ger eng:OFF

Windows (installed): mkvaudiosubtitlechanger.jar --library "X:/Files" --attribute-config eng:ger eng:OFF

Safe usage (best for testing before applying to whole library)

Portable: java -jar mkvaudiosubtitlechanger-<version>.jar --library "X:/Files" --attribute-config eng:ger eng:OFF --safe-mode

Windows (installed): mkvaudiosubtitlechanger.jar --library "X:/Files" --attribute-config eng:ger eng:OFF --safe-mode

Attribute-config must be entered in pairs: audio:subtitle; Example: jpn:eng. More about this topic here.

Available parameters

  -a, --attribute-config=<attributeConfig>...
                            List of audio:subtitle pairs used to match in order and update files accordingly (e.g. jpn:eng jpn:ger)
  -c, --coherent=<coherent> try to match all files in dir of depth with the same attribute config
      -cf, --force-coherent changes are only applied if it's a coherent match
      --commentary-keywords=<commentaryKeywords>[, <commentaryKeywords>...]...
                            Keywords to identify commentary tracks (Defaults will be overwritten; Default: commentary, director)
  -d, --filter-date=<filterDate>
                            only consider files created newer than entered date (format: "dd.MM.yyyy-HH:mm:ss")
  -e, --excluded-directory=<excludedDirectories>...
                            Directories to be excluded, combines with config file
      --forced-keywords=<forcedKeywords>[, <forcedKeywords>...]...
                            Keywords to identify forced tracks (Defaults will be overwritten; Default: forced, signs, songs)
  -h, --help                Show this help message and exit.
  -i, --include-pattern=<includePattern>
                            include files matching pattern (default: ".*")
  -l, --library=<libraryPath>
                            path to library
  -m, --mkvtoolnix=<mkvToolNix>
                            path to mkvtoolnix installation
  -n, --only-new-file       sets filter-date to last successful execution (overwrites input of filter-date)
      --preferred-subtitles=<preferredSubtitles>[, <preferredSubtitles>...]...
                            Keywords to prefer specific subtitle tracks (Defaults will be overwritten; Default: unstyled)
  -s, --safemode            test run (no files will be changes)
  -t, --threads=<threads>   thread count (default: 2)
  -V, --version             Print version information and exit.

If you need more information how each parameter works, check out this wiki page.

All parameters can also be defined in a config file.

Build requirements

  • JDK 21 or newer
  • Maven 3
  • Git

Build from source

git clone https://github.com/RatzzFatzz/MKVAudioSubtitleChanger.git
cd MKVAudioSubtitleChanger
mvn clean package -Pportable