subprocess.Popen的编码问题

import subprocess

def test1():
    test_monkey = subprocess.Popen('adb devices',stdout=subprocess.PIPE, stderr=subprocess.PIPE)
    return test_monkey.stdout.read().decode("utf-8")
txt =test1()
print(txt)

第一次没有加红字的decode时,输出的是二进制。加上红字代码之后,就可以跟正常的从cmd输入命令是 一样的了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
当`subprocess.Popen`进行子进程管理时,可能会出现各种报错。根据引用和引用的内容,报错`'UnicodeDecodeError: "gbk" code can't decode byte 0x80 in position 88 : illegal multibyte sequence'`是由于读取行时遇到了GBK编码无法解码的字节序列导致的。 解决这个报错的方法是在使用`subprocess.Popen`时,添加`universal_newlines=True`参数,如引用所示。这个参数可以将输入和输出流转换为文本模式,避免编码问题。 另外,引用中的报错`OSError: [Errno 2] No such file or directory`是因为`subprocess.Popen`的第一个参数所指定的命令或文件不存在。要解决这个问题,需要检查命令或文件路径是否正确。 综上所述,当使用`subprocess.Popen`时,常见的报错有编码问题和文件不存在问题,可以通过添加`universal_newlines=True`参数和检查命令或文件路径来解决。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [subprocess.popen中p.stdout.readline()编码格式报错gbk](https://blog.csdn.net/ol_m_lo/article/details/118676589)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [python3 subprocess.Popen 报错 No such file or directory](https://blog.csdn.net/whatday/article/details/107871094)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值