本文介绍如何使用python高效遍历文本文件,精准定位并输出所有包含目标字符串的行及其行号,避免常见索引错误,提升代码健壮性与可读性。
在处理日志、配置或设备接口信息等结构化文本时,常需检索特定关键词(如 AP/VLAN)出现的所有位置。原始代码虽能匹配,但使用 lines.index(line) 存在严重隐患:当文件中存在重复行时,index() 总是返回该内容首次出现的行号,导致行号错乱;同时,.find() != -1 的写法不如 in 运算符简洁直观。
推荐采用以下优化方案:
findString = "AP/VLAN"
with open('interfaces.txt', 'r', encoding='utf-8') as f:
for line_num, line in enumerate(f, start=1):
if findString in line:
print(f'String Found in Line Number: {line_num}')
print(f'Line Content: {line.rstrip()}')✅ 关键改进说明:
d() != -1; ⚠️ 注意事项:
此方法简洁、可靠、符合Python惯用法,适用于绝大多数文本检索场景。