如何使用正则表达式搜索变量值

2024-10-01 11:37:11 发布

您现在位置:Python中文网/ 问答频道 /正文

我有多行,只需要选择那些包含特定值的行。 例如

[DEBUG] 2014-12-01 16:39:12,049 [1984] Agent Logger Initialized
[DEBUG] 2014-12-01 16:39:12,049 [2884] Agent Logger Initialized
[DEBUG] 2014-12-01 16:39:12,049 [2884] Agent Actuation Logger Initialized

所以我有一个变量var=1984。你知道吗

id=re.search(r'\[var\],s,re.I|re.M|re.S)
if id:
   print line

上面的正则表达式应该只搜索var=1984,并且应该打印包含该值“[1984]”的行。有人能建议怎么做吗?我需要这个在Linux中搜索,我正在使用Python2.6。你知道吗


Tags: debugreidsearchifvarlinuxline
3条回答

您还可以使用一个简单的if条件:

from io import StringIO

text = StringIO(u"""\
[DEBUG] 2014-12-01 16:39:12,049 [1984] Agent Logger Initialized
[DEBUG] 2014-12-01 16:39:12,049 [2884] Agent Logger Initialized
[DEBUG] 2014-12-01 16:39:12,049 [2884] Agent Actuation Logger Initialized
""")

for line in text:
    if '[1984]' in line:
        print line

[DEBUG] 2014-12-01 16:39:12,049 [1984] Agent Logger Initialized

这应该起作用:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import re
var = '\[1984\]'
with open("test.log")  as fp: # assuming your log file is test.log
    lines = fp.readlines()
    for line in lines:
        line = line.strip()
        if re.match(r'.*'+str(var)+'.*',line): # may be you want to add some more strict matching rules here.
            print line

# vim:ai:et:sts=4:sw=4:

这个正则表达式应该工作:

var=1984
reg = '.+'+str(var)+'.+'
id=re.search(reg,s,re.I|re.M|re.S)

或者简单来说:

import re

s = ['[DEBUG] 2014-12-01 16:39:12,049 [1984] Agent Logger Initialized',
     '[DEBUG] 2014-12-01 16:39:12,049 [2884] Agent Logger Initialized',
     '[DEBUG] 2014-12-01 16:39:12,049 [2884] Agent Actuation Logger Initialized']

var = 1984
for line in s:
    id = re.findall(r'.+%d.+' % var, line, re.I | re.M | re.S)
    if id:
        print line

输出:

[DEBUG] 2014-12-01 16:39:12,049 [1984] Agent Logger Initialized

相关问题 更多 >