我将编译一个重复出现的字符串列表(事务 ID)。我很困惑。我研究了正确的方法,觉得这段代码应该可以工作。但是,我在第二个街区做错了什么。第一个块正确编译了我想要的字符串列表。
我不能让第二个块工作。如果我简化,我可以使用打印列表中的每个值
for idx, val in enumerate(tidarray): print val
看来我现在应该能够使用该值来搜索该字符串的每一行,然后打印该行(实际上我将它与另一个搜索词结合使用以减少行读取的数量,但这是我的在进一步珩磨之前进行基本测试。
def main():
pass
samlfile= "2013-08-18 06:24:27,410 tid:5af193fdc DEBUG org.sourceid.saml20.domain.AttributeMapping] Source attributes:{SAML_AUTHN_CTX=urn:oasis:names:tc:SAML:2.0:ac:classes"
tidarray = []
for line in samlfile:
if "tid:" in line:
str=line
tid = re.search(r'(tid:.*?)(?= )', str)
if tid.group() not in tidarray:
tidarray.append(tid.group())
for line in samlfile:
for idx, val in enumerate(tidarray):
if val in line:
print line
有人可以建议对第二个代码块进行更正吗?我认识到两次读取文件并不是最优雅的解决方案......我在这里的主要目标是学习如何枚举列表并在后续代码中使用每个值。