0

尝试将变量替换为 re.search 时,我被卡住了。
我使用以下代码从文件中收集存储的正则表达式并将其保存到变量“正则表达式”中。在此示例中,存储的正则表达式用于从日志消息中查找带有端口号的 IP 地址。

for line in workingconf:
    regexsearch = re.search(r'regex>>>(.+)', line)
    if regexsearch:
        regex = regexsearch.group(1)
        print regex

#I use re.search to go through "data" to find a match.

data = '[LOADBALANCER] /Common/10.10.10.10:10'
alertforsrch = re.search(r'%s' % regex, data)
if alertforsrch:
    print "MATCH"
    print alertforsrch.group(1)
else:
    print "no match"

当这个程序运行时,我得到以下信息。

$ ./messageformater.py
/Common/([\d]{1,}\.[\d]{1,}\.[\d]{1,}\.[\d]{1,}:[\d]{1,})
no match

当我将 re.search 更改为以下内容时,它可以工作。正则表达式将从文件中获取,并且可能每次都不相同。这就是我尝试使用变量的原因。

for line in workingconf:
    regexsearch = re.search(r'regex>>>(.+)', line)
    if regexsearch:
        regex = regexsearch.group(1)
        print regex


alertforsrch = re.search(r'/Common/([\d]{1,}\.[\d]{1,}\.[\d]{1,}\.[\d]{1,}:[\d]{1,})', data)
if alertforsrch:
    print "MATCH"
    print alertforsrch.group(1)
else:
    print "no match"

####### Results ########
$./messageformater.py
/Common/([\d]{1,}\.[\d]{1,}\.[\d]{1,}\.[\d]{1,}:[\d]{1,})
MATCH
10.10.10.10:10
4

1 回答 1

0

对我来说很好...

为什么还要打扰字符串格式化程序呢?re.search(regex, data) 应该可以正常工作。

您可能在从文件中读取的正则表达式末尾有一个换行符 - 尝试 re.search(regex.strip(), data)

于 2013-03-29T20:17:00.947 回答