如何在python3中删除b符号


问题内容

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

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