Python re.search不起作用

时间:2016-03-02 07:13:50

标签: python regex

在下面的代码中面对nonetypr对象错误 有人可以帮忙吗?

from os import listdir
from os.path import isfile, join
import re, os

featureList = {}
featureFileNames = {}

tempList = [f for f in listdir('.') if isfile(join('.', f))]

for fileName in tempList:
  fileName = '.' + os.sep + fileName
  featureFile = open(fileName, 'r')
  featureInfo = featureFile.readlines(-1)
  featureFile.close()
  featureName = re.search(r'.*XYZ : +(\S+\d)',' '.join(featureInfo)).group(1)
  featureList[featureName]=fileName  

I do have more than one files are in the below format :
file 1 : 
ABC : 123
ASD : 1234
SADF : 2412
XYZ : 123

file2:
ABC : 3234
ASD : 123323
SADF : 12345
XYZ : 1234555

我无法得到错误的位置? 有人可以告诉我这是什么错误,我该如何解决?

1 个答案:

答案 0 :(得分:2)

在您的代码示例中,正则表达式与您提供的文件示例不匹配。 XYZ之后有一个缺少的空格:

  featureName = re.search(r'.*XYZ : +(\S+\d)',' '.join(featureInfo)).group(1)

此外,为了避免出现NoneType错误,您应该在将re.search用作地图密钥之前对其进行测试。