python 读取文件名发生诡异的错误

2014-03-04 18:28:41 +08:00
 wind198501
背景:想写个遍历邮件列出收件人、发件人的程序,先用foxmail把自己邮箱的邮件下下来,再导出(eml格式)到一个文件夹里,再用代码遍历每个eml邮件文件,再分析出收件人、发件人信息。

诡异现象:碰到一个邮件名很诡异的,文件名链接: http://pan.baidu.com/s/1eQ66pjW (记得把文件下下来看哦)
windows7下看文件名一切正常。但是在cmd下dir命令查看,发现文件名中间有一个诡异的空格,截图: http://pan.baidu.com/s/1jDKtC

自己写的部分代码如下: http://pan.baidu.com/s/1jGwUC6M
发现运行时,在文件open操作时发生错误。同时在错误信息中,在cmd下看文件名空格的地方是一个小问号。截图: http://pan.baidu.com/s/1bnCHV7D

求大神解答啊!实在是弄不懂的了。。。郁闷。。。
2970 次点击
所在节点    Python
4 条回复
lgh
2014-03-04 23:01:31 +08:00
把文件名复制下来保存到utf8编码的txt里,再用16进制文本编辑器打开看看它是什么
clino
2014-03-05 09:12:35 +08:00
在winxp下下载楼主的文件名会是: 北京海外高层次人才刊物投-稿.txt
在linux下下载的文件名是: 北京海外高层次人才刊物投稿.txt

建议你字符串打出来是问号,那用 print repr("字符串") 这样看看那个东东到底是啥字符
wind198501
2014-03-05 15:33:35 +08:00
用print repr 打印出来如下:\xb1\xb1\xbe\xa9\xba\xa3\xcd\xe2\xb8\xdf\xb2\xe3\xb4\xce\xc8\xcb\xb2\xc5\xbf\xaf\xce\xef\xcd\xb6?\xb8\xe5

中间有个万恶的问号...奔溃了。。。不知道什么编码问题。。。
clino
2014-03-05 21:02:36 +08:00
>>> print "\xb1\xb1\xbe\xa9\xba\xa3\xcd\xe2\xb8\xdf\xb2\xe3\xb4\xce\xc8\xcb\xb2\xc5\xbf\xaf\xce\xef\xcd\xb6?\xb8\xe5".decode("gbk")
北京海外高层次人才刊物投?稿

我记得在windows下文件名是不允许为?问号的吧? 因为这个出的错?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/102860

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX