
本文介绍如何使用python高效遍历文本文件,精准定位并打印所有包含目标字符串的行,避免常见索引错误,同时提供可读性强、健壮性高的实现方案。
在处理日志、配置或设备输出类文本文件时,我们常需检索特定关键字(如 AP/VLAN)出现的所有位置,并完整输出对应行。原始代码虽能工作,但存在两个关键问题:一是使用 lines.index(line) 会导致重复匹配同一行(当文件中存在相同内容的多行时,.index() 永远返回首次出现的索引);二是 .find() != -1 判断不如 in 运算符简洁直观。
以下是推荐的优化写法,采用 enumerate() 直接获取行号与内容,语义清晰且无索引歧义:
find_string = "AP/VLAN"
with open('interfaces.txt', 'r', encoding='utf-8') as f:
for line_num, line in enumerate(f, start=1):
if find_string in line:
print(f'String Found in Line Number: {line_num}')
print(f'Line Content: {line.rstrip()}')✅ 关键改进说明:
- 使用 enumerate(f, start=1) 直接逐行迭代文件对象(无需 readlines() 全部载入内存),节省资源,尤其适合大文件;
- line.rstrip() 替代 strip() 可保留行首空格(如示例中缩进的 * AP/VLAN),更忠于原始格式;
- 显式指定 encoding='utf-8' 避免中文或特殊字符引发解码异常;
- in 操作符比 str.find() != -1 更符合 Python 习惯,性能相当且可读性更高。
⚠️ 注意事项:
立即学习“Python免费学习笔记(深入)”;
- 若需忽略大小写匹配,可改为 if find_string.lower() in line.lower():;
- 若需精确匹配单词(如避免匹配 AP/VLAN-EXT),建议结合正则表达式 re.search(r'\bAP/VLAN\b', line);
- 生产环境中建议添加 try...except FileNotFoundError 处理文件不存在的情况。
该方法简洁、可靠、易扩展,是文本行级模式匹配的标准实践。











