python3中os.popen()使用出错的解决方法
小编给大家分享一下python3中os.popen()使用出错的解决方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名注册、网络空间、营销软件、网站建设、广丰网站维护、网站推广。
在当前 desktop 目录下,有如下内容:
desktop $ls client.py server.py 中文测试 arcpy.txt codetest.py test.py
如上所示:有一个中文命名的文件 ----> 中文测试
# -*- coding:utf-8 -*- # python3.5.1 import os,sys print (sys.getdefaultencoding()) #系统默认编码 dir_list = os.listdir() for li in dir_list: print (li)
输出如下:
utf-8 arcpy.txt client.py codetest.py server.py test.py 中文测试
可以看出默认编码为 utf-8,os.listdir()命令可以正常输出中文字符。
在使用 os.popen()时:
# -*- coding:utf-8 -*- # python3.5.1 import os,sys print (sys.getdefaultencoding()) #系统默认编码 dir_list = os.popen('ls','r').read() for li in dir_list: print (li)
报错如下:
utf-8 Traceback (most recent call last): File "Desktop/codetest.py", line 8, indir_list = os.popen('ls','r').read() File "/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/encodings/ascii.py", line 26, in decode return codecs.ascii_decode(input, self.errors)[0] UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 76: ordinal not in range(128)
解决:
命令行执行没有问题,这个是编辑器的事。建议用subprocess
以上是python3中os.popen()使用出错的解决方法的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!
分享文章:python3中os.popen()使用出错的解决方法
文章链接:http://hbruida.cn/article/psgeei.html