python - 如何删除python3中的b符号

标签 python python-3.x

如何从 python3 脚本中删除 b 符号?

import subprocess

get_data=subprocess.check_output(["df -k | awk '{print $6}'"],shell=True)
data_arr=get_data.split()
data_arr.pop(0)
data_arr.pop(0)
for i in data_arr[:]:
    print(str(i))

输出

b'/dev/shm'
b'/run'
b'/sys/fs/cgroup'
b'/'
b'/tmp'
b'/test'
b'/boot'
b'/home'
b'/var'
b'/mnt/install'
b'/mnt/snapshot'
b'/mnt/share'
b'/mnt/storage'
b'/mnt/linux'
b'/mnt/download'
b'/run/user/1001'

最佳答案

b 符号表示 check_process 的输出是 bytes 而不是 str。删除它的最佳方法是在对其进行任何进一步处理之前将输出转换为字符串:

byte_data=subprocess.check_output(["df -k | awk '{print $6}'"],shell=True)
str_data = byte_data.decode('utf-8')
data_arr=str_data.split()
...

decode 方法将处理字符串中可能包含的任何 unicode。如果您的默认编码(或者我想 awk 使用的编码)不是 UTF-8,请替换上面示例中的正确编码。

解决这个问题的更好方法可能是告诉 check_output 打开 stdout 作为文本流。最简单的方法是添加一个 universal_newlines=True 参数,它将使用当前语言环境的默认编码:

str_data = subprocess.check_output(["df -k | awk '{print $6}'"], shell=True, universal_newlines=True)

或者,您可以指定显式编码:

str_data = subprocess.check_output(["df -k | awk '{print $6}'"], shell=True, encoding='utf-8')

在这两种情况下,您都不需要解码,因为输出已经是 str 而不是 bytes

关于python - 如何删除python3中的b符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43396792/

相关文章:

python - 重新引发自定义异常的正确方法是什么?

python - 将函数 1 中元组的所有元素(从 *args)传递到 python 中的函数 2(作为 *args)

python - urlparse.urlparse 在方案后返回 3 '/' 而不是 2

python - 在 Django 中随机排列查询集

python-3.x - 模块未找到错误 : No module named '_sqlite3'

linux - 我被硬件黑客入侵/后门了吗?

python-3.x - 安装python的邮政(地址解析器)包时出现问题

python - 如何用 pandas DataFrame 中的最后一个条目填充缺失的日期?

python - 与 numpy.logspace() 函数相比,如何用 C++ 编写更快的代码?

python - 高级 Python 正则表达式 : how to evaluate and extract nested lists and numbers from a multiline string?