如何在Python中查找并打印文件中所有包含指定字符串的行

11次阅读

如何在Python中查找并打印文件中所有包含指定字符串的行

本文介绍如何使用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/VLANb’, line);
  • 生产环境中建议添加 try…except FileNotFoundError 处理文件不存在的情况。

该方法简洁、可靠、易扩展,是文本行级模式匹配的标准实践。

text=ZqhQzanResources