介绍
这篇文章主要为大家展示了Python如何忽略文件名编码,内容简而易懂,希望大家可以学习一下,学习完之后肯定会有收获的,下面让小编带大家一起来看看吧。
<强>问题强>
你想使用原始文件名执行文件的I/O操作,也就是说文件名并没有经过系统默认编码去解码或编码过。
<强>解决方案强>
默认情况下,所有的文件名都会根据<代码> sys.getfilesystemencoding() 代码>返回的文本编码来编码或解码。比如:
在祝辞祝辞sys.getfilesystemencoding () & # 39;utf - 8 # 39; 祝辞祝辞祝辞
如果因为某种原因你想忽略这种编码,可以使用一个原始字节字符串来指定一个文件名即可。比如:
在祝辞祝辞# Wrte文件使用unicode文件名 在在在张开(& # 39;jalape \ xf1o.txt& # 39;, & # 39; w # 39;) f: …f.write(& # 39;辣! & # 39;) … 6 在在在#目录清单(解码) 在在在进口操作系统 在在在os.listdir(& # 39; # 39;公司) [& # 39;jalape& ntilde o.txt& # 39;】 在在在#目录清单(生) 在在在os.listdir (b # 39; # 39;公司)#注:字节字符串 [b # 39; jalapen \ xcc \ x83o.txt& # 39;】 在在在#打开文件与原始文件名 在在在打开(b # 39; jalapen \ xcc \ x83o.txt& # 39;) f: …print (f.read ()) … 辣的! 祝辞祝辞祝辞
正如你所见,在最后两个操作中,当你给文件相关函数如<代码> open() 代码>和<代码> os.listdir() 代码>传递字节字符串时,文件名的处理方式会稍有不同。
<>强讨论强>
通常来讲,你不需要担心文件名的编码和解码,普通的文件名操作应该就没问题了。但是,有些操作系统允许用户通过偶然或恶意方式去创建名字不符合默认编码的文件。这些文件名可能会神秘地中断那些需要处理大量文件的Python程序。
读取目录并通过原始未解码方式处理文件名可以有效的避免这样的问题,尽管这样会带来一定的编程难度。
以上就是关于Python如何忽略文件名编码的内容,如果你们有学习到知识或者技能,可以把它分享出去让更多的人看的到。