程序在使用的时候难免会出错,如何从大代码中找出错误,不仅考验能力,更考验小伙伴们的耐心。非常焦虑,你辛辛苦苦打出来的代码还是不行,这是可以理解的。那么如果我们在 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, in <module>
dir_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学习推荐:
。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ Redis常用操作盘点12/28
- ♥ python如何给函数和模块起别名09/12
- ♥ python异常处理的过程12/31
- ♥ python绘图中如何添加汉字的坐标轴09/09
- ♥ python如何表示连续加法?09/15
- ♥ 如何在idea中安装python10/28
内容反馈