使用Regex匹配python中的字母数字字符列表

时间:2014-12-11 18:01:27

标签: python regex alphanumeric

我正在尝试逐行解析文件,并查看处理器发出的数据包数据,这些数据基本上以字母数字字符表示。我在Python中编写了一个正则表达式来读取模式并将数据包存储在列表中。

示例行:

Date Time ProcessName ActivityName : 55 34 00 aa c9 00 11 45 55

我的正则表达式:

r'([^\s]*?)\s([^\s]*?)\s([^\s]*?)\s([^\s]*?)\s(R.*?:)\s(\d|\D|\s)+$'

我必须将数据包数据[:之后显示的数字]添加到列表中并执行一些模式处理活动。当我运行我的脚本并打印match.group(6)时,它只是在列表中打印了一堆'\n'

我的剧本片段:

regex = r'([^\s]*?)\s([^\s]*?)\s([^\s]*?)\s([^\s]*?)\s(R.*?:)\s(\d|\D|\s)+$'
pattern = re.compile(regex) 

for line in content:
    match = pattern.search(line)
    if match:
       print match.group(6)

我应该如何使用正则表达式读取一组字母数字字符?

1 个答案:

答案 0 :(得分:3)

您可以使用re.findall直接删除它。

 (?<=:)\s*([\da-zA-Z]{2}(?:\s[\da-zA-Z]{2})*)

参见演示。

https://regex101.com/r/eZ0yP4/13