我有一些代码来解析linux'df -h',正常的命令行输出如下所示:
Filesystem Size Used Avail Use% Mounted on
udev 987M 0 987M 0% /dev
tmpfs 201M 9.2M 191M 5% /run
/dev/sda1 38G 11G 25G 30% /
tmpfs 1001M 416K 1000M 1% /dev/shm
tmpfs 5.0M 0 5.0M 0% /run/lock
tmpfs 1001M 0 1001M 0% /sys/fs/cgroup
tmpfs 201M 28K 201M 1% /run/user/132
tmpfs 201M 28K 201M 1% /run/user/0
目前我的代码实现了所需的输出:
['/run', '/run/lock', '/run/user/132', '/run/user/0']
但是下面显示的'print([x.split(“”)[ - 1] for x in newlist])'行感觉就像一个黑客,我正在努力让这个作为正则表达式使用'r。在下面搜索,有人可以建议更好的方法吗?
import subprocess
import re
cmd = 'df -h'
output = subprocess.check_output(cmd, shell=True).decode('utf8')
ln = output.split('\n')
r = re.compile('/run.*')
newlist = list(filter(r.search, ln))
print ([x.split(" ")[-1] for x in newlist])
编辑*我使用'df -h'作为一些随机输出来练习正则表达式,所以虽然@romanPerekhrest为这个问题提供了最好的真实世界解决方案,但我一直在寻找一个正则表达式解决方案。
答案 0 :(得分:3)
最快的方法:
.slice()
输出:
df -h --output=target | grep '/run.*'
/run
/run/lock
/run/user/132
/run/user/0
- 仅输出挂载点答案 1 :(得分:2)
怎么样
re.findall(r'/run.*$', output, re.MULTILINE)
我不知道更好还是速度,但是它会将你的代码减少到3行,而且无论如何你仍然在重复。