# Subtitle details for i, stream in enumerate(subtitle_streams): print(f"\nš Subtitle Stream {i}:") print(f" Codec: {stream.get('codec_name', 'Unknown')}") print(f" Language: {stream.get('tags', {}).get('language', 'Unknown')}") display_mkv_info("1234.mkv") 2. Stream Extraction Feature def extract_streams(filepath="1234.mkv"): """Extract individual streams from MKV""" streams = analyze_mkv(filepath)
# Extract audio subprocess.run([ 'ffmpeg', '-i', filepath, '-map', '0:a:0', '-c', 'copy', '1234_audio.aac' ]) 1234 mkv
# Extract subtitles if present subprocess.run([ 'ffmpeg', '-i', filepath, '-map', '0:s:0', '-c', 'copy', '1234_subtitles.srt' ]) print("ā Streams extracted from 1234.mkv") def remux_mkv(filepath="1234.mkv", output="1234_remuxed.mkv"): """Remux MKV to optimize or remove streams""" # Remove unwanted streams (example: keep only first video and audio) subprocess.run([ 'ffmpeg', '-i', filepath, '-map', '0:v:0', '-map', '0:a:0', '-c', 'copy', output ]) # Subtitle details for i
print(f"\nš Streams: {len(video_streams)} video, {len(audio_streams)} audio, {len(subtitle_streams)} subtitle") 'Unknown')}") print(f" Language: {stream.get('tags'
if "error" in info: print(f"ā {info['error']}") return
# Stream analysis streams = info['streams'] video_streams = [s for s in streams if s['codec_type'] == 'video'] audio_streams = [s for s in streams if s['codec_type'] == 'audio'] subtitle_streams = [s for s in streams if s['codec_type'] == 'subtitle']