Python 代码简化优化:解析视频信息/n/n本文将展示如何使用 Python 代码简化并优化解析视频信息的过程,包括获取视频文件名、大小、时长、分辨率、码率、帧率、音频信息等。/n/n原始代码:/n/npython/nimport os/nimport re/nimport subprocess/nimport math/n/n# 视频格式/nsupported_formats = ['.mp4', '.avi', '.mkv', '.wmv', '.mov', '.flv', '.m2ts', '.ts', '.rm', '.rmvb',/n '.vob', '.3gp', '.webm', '.hdmov', '.mp4v', '.mpv4', '.divx', '.xvid', '.f4v',/n '.mpeg', '.asf', '.asx', '.m2t']/n# 视频文件夹/nvideo_folder = '/home/115/up'/n# 正则表达式匹配码率数据中的空格/npattern = re.compile(r'(/d+)/s+(/d+)')/n# 获取视频文件列表(包括子目录)/nvideo_files = []/nfor root, dirs, files in os.walk(video_folder):/n for file in files:/n for format in supported_formats:/n if file.endswith(format):/n video_files.append(os.path.join(root, file))/n break/n/n# 遍历所有视频文件/nfor video_file in video_files:/n # 获取文件名/n file_name = os.path.basename(video_file)/n/n # 获取文件大小并进行单位换算/n size = os.path.getsize(video_file)/n if size < 1024:/n size_str = f'{size} B'/n elif size < 1024 * 1024:/n size_str = f'{size / 1024:.2f} KiB'/n elif size < 1024 * 1024 * 1024:/n size_str = f'{size / 1024 / 1024:.2f} MiB'/n else:/n size_str = f'{size / 1024 / 1024 / 1024:.2f} GiB'/n/n # 使用mediainfo获取视频信息 / 音频信息/n video_result = subprocess.run(['mediainfo', '--Inform=Video;%Format%|%Width%x%Height%|%BitRate/String%|%FrameRate%|%Duration/String3%', video_file], stdout=subprocess.PIPE)/n video_output = video_result.stdout.decode().strip()/n audio_result = subprocess.run(['mediainfo', '--Inform=Audio;%BitRate/String%|%SamplingRate/String%|%Language/String%', video_file], stdout=subprocess.PIPE)/n audio_output = audio_result.stdout.decode().strip()/n/n # 解析输出结果/n video_info = video_output.split('|')/n audio_info = audio_output.split('|')/n/n # 处理多音轨情况/n audio_bitrate = []/n audio_sampling_rate = []/n audio_lang = []/n for i in range(len(audio_info) // 3):/n audio_bitrate.append(audio_info[i * 3])/n audio_sampling_rate.append(audio_info[i * 3 + 1])/n audio_lang.append(audio_info[i * 3 + 2])/n/n # 时长取整/n duration = video_info[4].split('.')[0]/n h, m, s = duration.split(':')/n duration = f'{h}:{m}:{str(s).zfill(2)}'/n/n # 以分钟计算的时长 2/n duration_minutes = int(h) * 60 + int(m) + math.ceil(float(s)) / 60/n/n # 计算压缩比率/n ratio = round(duration_minutes / size * 1000000000, 2)/n/n # 使用正则表达式替换码率数据中第一个数字和第二个数字之间的空格/n bitrate = re.sub(pattern, r'/1/2', video_info[2])/n/n # 获取帧率/n try:/n framerate = float(video_info[3])/n except ValueError:/n framerate = None/n/n # 打印文件信息/n print(f'{file_name}, {size_str}, {duration}, {video_info[1]}, {bitrate}, {framerate}, {' / '.join(audio_lang)}, {ratio}')/n/n/n简化优化后的代码:/n/npython/nimport os/nimport re/nimport subprocess/nimport math/n/n# 视频格式/nsupported_formats = ['.mp4', '.avi', '.mkv', '.wmv', '.mov', '.flv', '.m2ts', '.ts', '.rm', '.rmvb',/n '.vob', '.3gp', '.webm', '.hdmov', '.mp4v', '.mpv4', '.divx', '.xvid', '.f4v',/n '.mpeg', '.asf', '.asx', '.m2t']/n# 视频文件夹/nvideo_folder = '/home/115/up'/n# 正则表达式匹配码率数据中的空格/npattern = re.compile(r'(/d+)/s+(/d+)')/n/n# 获取视频文件列表(包括子目录)/nvideo_files = [os.path.join(root, file) for root, _, files in os.walk(video_folder) for file in files/n if os.path.splitext(file)[-1].lower() in supported_formats]/n/n# 遍历所有视频文件/nfor video_file in video_files:/n # 获取文件名/n file_name = os.path.basename(video_file)/n/n # 获取文件大小并进行单位换算/n size = os.path.getsize(video_file)/n size_str = f'{size} B' if size < 1024 else f'{size / 1024:.2f} KiB' if size < 1024 * 1024 else ///n f'{size / 1024 / 1024:.2f} MiB' if size < 1024 * 1024 * 1024 else f'{size / 1024 / 1024 / 1024:.2f} GiB'/n/n # 使用mediainfo获取视频信息 / 音频信息/n video_result = subprocess.run(/n ['mediainfo', '--Inform=Video;%Format%|%Width%x%Height%|%BitRate/String%|%FrameRate%|%Duration/String3%',/n video_file], stdout=subprocess.PIPE)/n video_output = video_result.stdout.decode().strip()/n audio_result = subprocess.run(/n ['mediainfo', '--Inform=Audio;%BitRate/String%|%SamplingRate/String%|%Language/String%', video_file],/n stdout=subprocess.PIPE)/n audio_output = audio_result.stdout.decode().strip()/n/n # 解析输出结果/n video_info = video_output.split('|')/n audio_info = audio_output.split('|')/n/n # 处理多音轨情况/n audio_bitrate, audio_sampling_rate, audio_lang = zip(/n *((audio_info[i * 3], audio_info[i * 3 + 1], audio_info[i * 3 + 2]) for i in range(len(audio_info) // 3)))/n/n # 时长取整/n duration = f'{video_info[4].split('.')[0]}:{video_info[4].split('.')[-1].zfill(2)}'/n duration_minutes = int(video_info[4][:2]) * 60 + int(video_info[4][3:5]) + math.ceil(float(video_info[4][6:])) / 60/n/n # 计算压缩比率/n ratio = round(duration_minutes / size * 1000000000, 2)/n/n # 使用正则表达式替换码率数据中第一个数字和第二个数字之间的空格/n bitrate = re.sub(pattern, r'/1/2', video_info[2])/n/n # 获取帧率/n framerate = float(video_info[3]) if '.' in video_info[3] else None/n/n # 打印文件信息/n print(f'{file_name}, {size_str}, {duration}, {video_info[1]}, {bitrate}, {framerate}, {' / '.join(audio_lang)}, {ratio}')/n/n/n优化点:/n/n1. 使用列表推导获取视频文件列表: 简化了原先使用循环嵌套的方式,提高代码简洁性。/n2. 使用条件表达式简化文件大小单位换算: 使代码更紧凑。/n3. 使用 zip 函数处理多音轨情况: 简化了原先使用循环的代码。/n4. 优化时长格式化: 直接使用 split('.') 方法获取时长的小数部分,避免了额外的字符串拼接操作。/n5. 优化帧率处理: 使用 if '.' in video_info[3] 判断帧率是否为浮点数,提高代码鲁棒性。/n/n代码改进:/n/n- 使用 os.path.splitext(file)[-1].lower() 获取文件扩展名,简化了原先使用循环判断的方式。/n- 使用 zip 函数处理多音轨情况,简化了原先使用循环的代码。/n- 优化了时长格式化和帧率处理逻辑,提高代码的可读性和鲁棒性。/n/n通过以上优化,代码变得更加简洁、高效,可读性也得到了提升。/n

Python 代码简化优化:解析视频信息

原文地址: https://www.cveoy.top/t/topic/mHjU 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录