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
meowoo
V2EX  ›  Python

关于 Python 读取文件时候的编码

  •  
  •   meowoo · 2018-05-29 21:50:02 +08:00 via iPhone · 2355 次点击
    这是一个创建于 2150 天前的主题,其中的信息可能已经有所发展或是发生改变。
    今天在一个镜像机上安装 python3

    安完之后测试的时候一直报不能用 ascii 解码的错误

    然后 sys.getfilesystemencoding()的结果是 ascii

    问下这个跟机器的编码有关么。也没找到怎么修改
    10 条回复    2018-05-30 21:28:44 +08:00
    crb912
        1
    crb912  
       2018-05-29 22:26:14 +08:00 via Android
    说了半天,上代码和文件的内容啊?

    试试:
    f = open(r'yourFilePath', encoding='某某编码')

    如果报 某某编码 can't decde at xx position...
    说明文件就不是那个编码。更准确的说,文件中可能使用了其它的编码的字符或符号。

    最好的办法,就是用二进制查看工具看下。对于 ASCII,看下是否有超过 127(也就是 16 进制:EF)的,如果有,说明就不是纯 ASCII。

    我猜测是这种可能性比较大。

    或者文件给我发一份。
    F1024
        2
    F1024  
       2018-05-29 22:29:21 +08:00
    读取的时候加上编码类型不就行了。
    bearqq
        3
    bearqq  
       2018-05-29 22:32:31 +08:00 via Android
    文件相关用 codecs 库,不要直接 open
    meowoo
        4
    meowoo  
    OP
       2018-05-30 00:54:05 +08:00 via iPhone
    @crb912 用的是 logging .config.configfile()打开的一个配置文件 文件保存的是 asciiascii filefile 命令查看是 isoiso 那个类型 这个函数又不能指定编码 所以很纠结
    meowoo
        5
    meowoo  
    OP
       2018-05-30 00:54:49 +08:00 via iPhone
    @F1024 是 logging 的那个打开配置文件的方法 我看了一下没有指定编码的参数
    Sylv
        6
    Sylv  
       2018-05-30 02:13:38 +08:00 via iPhone
    上代码和报错信息,要不然只能瞎猜。
    meowoo
        7
    meowoo  
    OP
       2018-05-30 14:58:51 +08:00 via iPhone
    @crb912 感谢 果然还是文件不是纯 ascii 编码 重新转码就 ok 了
    meowoo
        8
    meowoo  
    OP
       2018-05-30 15:01:03 +08:00 via iPhone
    @Sylv 已经搞定了 就是因为文件不是纯 ascii 而是 iso-8859 但是还有一个问题 就是为啥是默认用 ASCII 去读取 怎么修改呢
    Sylv
        9
    Sylv  
       2018-05-30 15:43:45 +08:00 via iPhone
    @meowoo
    logging.config.fileconfig() 是用 open() 方法来读取文件的,open() 默认使用的编码是 locale.getpreferredencoding(False) 返回的编码,这个编码是由运行环境的语言环境变量判断来的,可能是你机子的语言环境变量没设置好。
    或者可以用正确的编码打开文件后,再传给 logging.config.fileconfig():
    with open('filename', encoding='utf-8') as f:
    logging.config.fileconfig(f)
    meowoo
        10
    meowoo  
    OP
       2018-05-30 21:28:44 +08:00 via iPhone
    @Sylv 好的 学习了 多谢大佬
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3661 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 04:58 · PVG 12:58 · LAX 21:58 · JFK 00:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.