属性组不属于对象

时间:2013-07-15 09:16:59

标签: python

如果我在脚本开头声明“line”变量,则以下代码按预期工作。类似......

s = "Jul 15 12:12:51 whitelist logger: 1|999999999999|id:d9faff7c-4016-4343-b494-37028763bb66 submit date:1307130919 done date:1307130919 stat:DELIVRD err:0|L_VB3_NM_K_P|1373687445|vivnel2|L_VB3_GH_K_P|promo_camp1-bd153424349bc647|1"

当我打开文件并循环遍历行时,groups属性不起作用。我收到一个错误:AttributeError:'NoneType'对象没有属性'groups'

# cat mylast.py
import re

f = open('customer.csv')

for line in f:

      logger_re = re.compile(
     "logger: ([^ ]+)\
      submit date:(\d+)\
      done date:(\d+)\
      stat:(.+)\
      err:(.+)$")
      myvalues = logger_re.search(line).groups()
      print myvalues

f.close()

例外:

# python mylast.py
Traceback (most recent call last):
  File "mylast.py", line 13, in ?
    myvalues = logger_re.search(line).groups()
AttributeError: 'NoneType' object has no attribute 'groups'

2 个答案:

答案 0 :(得分:2)

您的正则表达式与您的实际文件内容不匹配。

因此,logger_re.search(line)会返回None

这里的问题是你缩进你的正则表达式,但没有补偿额外的空格:

logger_re = re.compile(
     "logger: ([^ ]+)\
      submit date:(\d+)\
      done date:(\d+)\
      stat:(.+)\
      err:(.+)$")

请注意,的行开头处的空格很重要。使用单独的字符串(Python将在编译时加入它们):

logger_re = re.compile(
     "logger: ([^ ]+) "
     "submit date:(\d+) "
     "done date:(\d+) "
     "stat:(.+) "
     "err:(.+)$")

答案 1 :(得分:0)

如果未找到匹配项,您的搜索将返回None。在尝试访问myvalues is not None之前,您需要先检查groups()