V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
wind198501
V2EX  ›  Python

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

  •  
  •   wind198501 · 2014-03-04 18:28:41 +08:00 · 3043 次点击
    这是一个创建于 3921 天前的主题,其中的信息可能已经有所发展或是发生改变。
    背景:想写个遍历邮件列出收件人、发件人的程序,先用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

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

    建议你字符串打出来是问号,那用 print repr("字符串") 这样看看那个东东到底是啥字符
    wind198501
        3
    wind198501  
    OP
       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
        4
    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下文件名是不允许为?问号的吧? 因为这个出的错?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5888 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 33ms · UTC 01:50 · PVG 09:50 · LAX 17:50 · JFK 20:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.