使用程序难免会有出错的时候,如何从大篇代码中找出错误,不仅考验能力,还要考验小伙们的耐心。辛辛苦苦敲出的代码运行不出结果,非常着急是可以理解的。那么我们在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
对于这个解决方法,有的小伙伴们觉得太简单了,但是我们找寻方法的过程是困难的,学会的赶紧保存吧。更多Python学习推荐:PyThon学习网教学中心。
当前文章:创新互联Python教程:python3中os.popen()使用出错怎么办?
本文网址:http://www.gawzjz.com/qtweb/news27/202027.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联