如何去除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))
Output
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'
The b
符号表示输出check_process
is a 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()
...
The 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
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)