TLDR:有没有一种干净的方法来为 subprocess.check_output('pcregrep', '-M', '-e', pattern, file) 制作条目列表?
我正在使用 pythonsubprocess.check_output()
来调用pcregrep -M
. 通常我会通过调用来分隔结果,splitlines()
但由于我正在寻找多行模式,所以这不起作用。我很难找到一种干净的方法来创建匹配模式列表,其中列表的每个条目都是一个单独的匹配模式。
这是一个简单的示例文件,我正在 pcgrep'ing
module test_module(
input wire in0,
input wire in1,
input wire in2,
input wire cond,
input wire cond2,
output wire out0,
output wire out1
);
assign out0 = (in0 & in1 & in2);
assign out1 = cond1 ? in1 & in2 :
cond2 ? in1 || in2 :
in0;
这是(一些)我的python代码
#!/usr/bin/env python
import subprocess, re
output_str = subprocess.check_output(['pcregrep', '-M', '-e',"^\s*assign\\s+\\bout0\\b[^;]+;",
"/home/<username>/pcregrep_file.sv"]).split(';')
# Print out the matches
for idx, line in enumerate(output_str):
print "output_str[%d] = %s" % (idx, line)
# Clear out the whitespace list entries
output_str = [line for line in output_str if re.match(\S+, line)]
这是输出
output_str[0] =
assign out0 = in0 & in1 & in2
output_str[1] =
assign out1 = cond1 ? in1 & in2 :
cond2 ? in1 || in2 :
in0
output_str[2] =
如果我能做类似的事情就好了
output_list = subprocess.check_output('pcregrep', -M, -e, <pattern>, <file>).split(<multiline_delimiter>)
没有创建垃圾来清理(空白列表条目),甚至没有一个split()
独立于模式的分隔符。
有没有一种干净的方法来创建匹配的多行模式列表?