diff --git a/Scripts-Divers/Batch Merge Subtitles with MKVMerge.ps1 b/Scripts-Divers/Batch Merge Subtitles with MKVMerge.ps1 new file mode 100644 index 0000000..7c1bba4 --- /dev/null +++ b/Scripts-Divers/Batch Merge Subtitles with MKVMerge.ps1 @@ -0,0 +1,120 @@ +##============================================================================================== +## ## +## Batch Merge Subtitles with MKVMerge ## +## By Miles ## +## Idea from Iain McCain : https://superuser.com/a/1249870 ## +## ## +##============================================================================================== +## ## +## Utilisation et conditions : ## +## - Il faut que les .srt et les .mkv soient dans le même dossier. ## +## - Il faut que les sous-titres externes .SRT aient le même nom de fichier que les .MKV. ## +## - Il faut paramétrer l'extension des fichiers de sous-titres pour que ces derniers ## +## reflètent la langue : eng, fre,... ## +## - Il faudra par ailleurs modifier le code langage dans AudioLang_X et SubTrackLang_1 ## +## Il est possible de : ## +## - spécifier des dossiers sources et destinations identiques ou différents ## +## - spécifier un titre de piste (pour toutes) ## +## ## +##============================================================================================== + +#Set MKVMerge.exe Path +$MKVMerge = 'H:\z_MKV\mkvtoolnix\mkvmerge.exe' + +#Set Source and Target directories (Don't put an \ at the end) +$sourceDirectory = "D:\DOSSIER_SOURCE" +$destinationDirectory = "F:\DOSSIER_DESTINATION" + +#If source and destination are the same folder, set this to True, Otherwise let it to "False" +$merged_SUFFIX_name = "False" + +#Set Subtitle Extension (Don't add the . before the extension) +$SubExtension = 'eng.srt' +#$SecondSubExtension = "sub" + +# Name and language of Audio Track n°1 +$AudioTrackName_1 = "English AC3 5.1" +$AudioLang_1 = "en" + +# Name of Audio Track n°2 +$AudioTrackName_2 = "Français AC3 2.0" +$AudioLang_2 = "fr" + +# Name and language of Subtitle Track n°1 + Sync Value +$SubTrackName_1 = "English SRT" +$SubTrackLang_1 = "en" +# Leave this at "0000" if no synchronisation modifier is to used, otherwise it's in ms +# +xxxx to delay the display of subtitles of xxxx ms +# -xxxx to advance the display of subtitles of xxxx ms +$SubSYNCvalue_1 = "0000" + +# Name and language of Subtitle Track n°2 +#$SubTrackName_2 = "Français SRT" +#$SubTrackLang_2 = "fr" +# Leave this at "0:0000" if no synchronisation modifier is to used, otherwise it's in ms : +# 0:+xxxx to delay the display of subtitles of xxxx ms +# 0:-xxxx to advance the display of subtitles of xxxx ms +#$SubSYNCvalue_2 = "0:1000" + +##============================================================================================== +##============================================================================================== + +# Testing if the Not-Merged folder already exists : if yes, it will be renamed, else it will be created. +$Path_Folder_NotMerged = $sourceDirectory + "\Not-Merged" +If(!(test-path $Path_Folder_NotMerged)) { + New-Item -ItemType "Directory" -Force -Path $Path_Folder_NotMerged -Verbose +} else { + # Don't know what's the best... TO BE IMPROVED + #Move-Item -Path $Path_Folder_NotMerged -Destination "$sourceDirectory\Not-Merged--backup" -Verbose + #Move-Item -Path $Path_Folder_NotMerged -Destination "$sourceDirectory\Not-Merged--backup" -Verbose +} + + +#Process +$Subs = Get-ChildItem $sourceDirectory -Filter "*.$SubExtension" | ForEach-Object { $_.FullName } | Sort-Object +$Count = $Subs.count +Write-Host "$Count MKV's to be processed." + +Foreach ($Sub in $Subs) { + #Get File Name + $FormatName = $Sub.ToString() + #$Name = $FormatName.TrimEnd(".$SubExtension") + $Name = $FormatName.Substring(0,$FormatName.Length-($SubExtension.Length+1)) + $MKV = $Name + '.mkv' + #$OtherSub = $Name + '.' + $SecondSubExtension + + # Title for the video track + $VideoTrackName = (Get-Item $MKV).Basename + + #Set Output File Name + #$Output = $Name + '___MERGED' + '.mkv' + If ($merged_SUFFIX_name -eq "True") { + $Output = $destinationDirectory + "\" + $VideoTrackName + '___MERGED' + '.mkv' + } elseif ($merged_SUFFIX_name -eq "False") { + $Output = $destinationDirectory + "\" + $VideoTrackName + '.mkv' + } else { + write-host "Error in the value of the merged_SUFFIX_name variable. Current value = $merged_SUFFIX_name" -foreground "red" + write-host "Should be set to True or False.`nScript is exiting now..." -foreground "white" + Exit + } + + #Execute + & $MKVMerge --title "$VideoTrackName" --track-order "0:0,0:1,0:2,1:0" -o "$Output" --no-subtitles --language "0:en" --track-name "0:$VideoTrackName" --default-track "0:yes" --language "1:$AudioLang_1" --track-name "1:$AudioTrackName_1" --default-track "1:yes" --language "2:$AudioLang_2" --track-name "2:$AudioTrackName_2" --default-track "2:no" "$MKV" --language "0:$SubTrackLang_1" --track-name "0:$SubTrackName_1" --default-track "0:yes" --sync "0:$SubSYNCvalue_1" "$Sub" + + If (Test-Path $Output) { + #Clean Up + #Remove-Item $MKV + #Remove-Item $Sub + #Remove-Item $OtherSub + # Move to folder Not-Merged, this folder's existence has already been tested, and the folder is created. + Move-Item -Path $MKV -Destination $Path_Folder_NotMerged -Verbose + Move-Item -Path $Sub -Destination $Path_Folder_NotMerged -Verbose + + # Renaming the output file is not necessary if the output filename doesn't have __MERGED in it + #Rename-Item -Path $Output -NewName $MKV -Verbose + + } Else { + write-host "File NON-EXISTANT - $Output" -foreground "red" + "File NON-EXISTANT - $Output" | Out-File "$destinationDirectory\Errors.txt" -Append + } +} \ No newline at end of file