Python Regex re.search列出

时间:2017-07-11 15:20:38

标签: python regex python-3.x

我有一些代码来解析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为这个问题提供了最好的真实世界解决方案,但我一直在寻找一个正则表达式解决方案。

2 个答案:

答案 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行,而且无论如何你仍然在重复。