Perl新手第一次使用Unicode的经验(在文件名,-e运算符,open运算符和cmd窗口中):
我有一个Windows Perl(5.16.1 32位)程序,该程序打开一个媒体文件,并(使用ffmpeg)提取音频片段-目的是将单个专辑音乐曲目(包含多首歌曲)转换为多首单独的歌曲 文件。
当要处理的媒体文件的名称全为ASCII字符时,这一切都很好。 最近,我针对包含俄语字符的文件名尝试了该程序,该程序在多个区域失败。
尽管这必须与Unicode有关,并且因为我以前从未需要对Unicode做任何事情-我对我在这里遇到的故障的各个方面感到困惑,也不知道解决各种问题的方法 现在面对。
我已将此精简到最低程度以演示问题。
如果我打开一个cmd窗口,然后键入’chcp’,则返回值为437。
如果我执行“ dir”命令,则显示给我的是:
(请注意,在我的cmd窗口中,俄语字符如何显示为俄语字符。)
我的“ test.pl” Perl脚本在这里:
当此Perl脚本运行时,使用默认chcp值437,将其作为输出输出:
Media file does NOT exist
Media file (IC