时间:2021-05-22
问题
你的程序获取了一个目录中的文件名列表,但是当它试着去打印文件名的时候程序崩溃, 出现了 UnicodeEncodeError 异常和一条奇怪的消息—— surrogates not allowed 。
解决方案
当打印未知的文件名时,使用下面的方法可以避免这样的错误:
def bad_filename(filename): return repr(filename)[1:-1]try: print(filename)except UnicodeEncodeError: print(bad_filename(filename))如果你有代码需要操作文件名或者将文件名传递给 open() 这样的函数,一切都能正常工作。 只有当你想要输出文件名时才会碰到些麻烦(比如打印输出到屏幕或日志文件等)。 特别的,当你想打印上面的文件名列表时,你的程序就会崩溃:
>>> for name in files:... print(name)...spam.pyTraceback (most recent call last): File "<stdin>", line 2, in <module>UnicodeEncodeError: 'utf-8' codec can't encode character '\udce4' inposition 1: surrogates not allowed>>>>>> for name in files:... try:... print(name)... except UnicodeEncodeError:... print(bad_filename(name))...spam.pyb\udce4d.txtfoo.txt>>>在 bad_filename() 函数中怎样处置取决于你自己。 另外一个选择就是通过某种方式重新编码,示例如下:
def bad_filename(filename): temp = filename.encode(sys.getfilesystemencoding(), errors='surrogateescape') return temp.decode('latin-1')译者注:
surrogateescape:
这种是Python在绝大部分面向OS的API中所使用的错误处理器,
它能以一种优雅的方式处理由操作系统提供的数据的编码问题。
在解码出错时会将出错字节存储到一个很少被使用到的Unicode编码范围内。
在编码时将那些隐藏值又还原回原先解码失败的字节序列。
它不仅对于OS API非常有用,也能很容易的处理其他情况下的编码错误。
使用这个版本产生的输出如下:
>>> for name in files:... try:... print(name)... except UnicodeEncodeError:... print(bad_filename(name))...spam.pybäd.txtfoo.txt>>>这一小节主题可能会被大部分读者所忽略。但是如果你在编写依赖文件名和文件系统的关键任务程序时, 就必须得考虑到这个。否则你可能会在某个周末被叫到办公室去调试一些令人费解的错误。
以上就是Python打印不合法的文件名的详细内容,更多关于Python 打印文件名的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
2017天猫开学季活动报名的时候,卖家朋友可能会遇到2017天猫开学爆到店铺承接页地址不合法,这是为什么?2017天猫开学爆到店铺承接页地址不合法天猫卖家应该怎
python-查找特定名称文件并按序号、文件名分行打印输出第1天第2题1.遍历”Day1-homework”目录下文件;2.找到文件名包含“2020”的文件;3
python修改FTP服务器上的文件名,具体代码如下所示:#-*-coding:utf-8-*-#修改ftp服务器上的文件名fromftplibimportFT
Python语言与Perl,C和Java等语言有许多相似之处,也有一定的差异性,以下是Python语言获取文件后缀名和文件名的方法:#Python获取文件后缀名
实现代码:#!/usr/bin/python//处理程序#filenamejiafa.py//文件名importsysimportrandomrunning=T