Oto skrypt w Pythonie, który szybko zhakowałem, aby rozwiązać pierwotny problem: zachowaj skompresowaną kopię biblioteki muzycznej. Skrypt skonwertuje pliki .m4a (zakłada się, że jest to ALAC) do formatu AAC, chyba że plik AAC już istnieje i jest nowszy niż plik ALAC. Pliki MP3 w bibliotece zostaną połączone, ponieważ są już skompresowane.
Uważaj tylko, że przerwanie skryptu ( ctrl-c) spowoduje pozostawienie w połowie przekonwertowanego pliku.
Początkowo chciałem również napisać Makefile, aby to obsłużyć, ale ponieważ nie może on obsługiwać spacji w nazwach plików (zobacz akceptowaną odpowiedź) i ponieważ napisanie skryptu bash gwarantuje, że wprowadzi mnie w świat bólu, jest nim Python. Jest dość prosty i krótki, a zatem powinien być łatwy do dostosowania do twoich potrzeb.
from __future__ import print_function
import glob
import os
import subprocess
UNCOMPRESSED_DIR = 'Music'
COMPRESSED = 'compressed_'
UNCOMPRESSED_EXTS = ('m4a', ) # files to convert to lossy format
LINK_EXTS = ('mp3', ) # files to link instead of convert
for root, dirs, files in os.walk(UNCOMPRESSED_DIR):
out_root = COMPRESSED + root
if not os.path.exists(out_root):
os.mkdir(out_root)
for file in files:
file_path = os.path.join(root, file)
file_root, ext = os.path.splitext(file_path)
if ext[1:] in LINK_EXTS:
if not os.path.exists(COMPRESSED + file_path):
print('Linking {}'.format(file_path))
link_source = os.path.relpath(file_path, out_root)
os.symlink(link_source, COMPRESSED + file_path)
continue
if ext[1:] not in UNCOMPRESSED_EXTS:
print('Skipping {}'.format(file_path))
continue
out_file_path = COMPRESSED + file_path
if (os.path.exists(out_file_path)
and os.path.getctime(out_file_path) > os.path.getctime(file_path)):
print('Up to date: {}'.format(file_path))
continue
print('Converting {}'.format(file_path))
subprocess.call(['ffmpeg', '-y', '-i', file_path,
'-c:a', 'libfdk_aac', '-vbr', '4',
out_file_path])
Oczywiście można to ulepszyć, aby wykonywać kodowanie równolegle. Czytelnikowi pozostawiam to jako ćwiczenie ;-)