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, in 
    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

python3中os.popen()使用出错的解决方法

以上是python3中os.popen()使用出错的解决方法的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


当前标题:python3中os.popen()使用出错的解决方法
网页网址:http://scyanting.com/article/psgeei.html