




本文介绍一种健壮、可扩展的方法:读取目标数字列表,逐个在csv文件中精确匹配各字段,避免因换行符、空格或子串误匹配导致的查找失败。
在处理类似“从 numberstofind.txt 中读取多个数值,并在 midvalues1.csv 中查找包含该数值的整行”这类任务时,初学者常犯的关键错误包括:
以下是一个专业、可复用的解决方案:
import csv
# 步骤1:安全读取待搜索数字(自动过滤空行和空白)
with open("numberstofind.txt", "r", encoding="utf-8") as f:
search_numbers = [line.strip() for line in f if line.strip()]
# 步骤2:对每个数字,在CSV中逐行、逐字段搜索
for idx, target in enumerate(search_numbers, start=1):
found = False
with open("midvalues1.csv", "r", encoding="utf-8") as csv_file:
reader = csv.reader(csv_file)
for row in reader:
# 精确匹配:检查 target 是否完整等于某一个单元格(避免子串误匹配)
if target in row:
matched_line = ",".join(row)
print(matched_line)
print(f"Found {target}!")
# 写入结果到独立文件
with open(f"ident{idx}.txt", "w", encoding="utf-8") as 
out_f:
out_f.write(matched_line + "\n")
found = True
break # 找到首个匹配即退出(如需全部匹配,移除此行)
if not found:
print(f"Data '{target}' not found!")✅ 关键优化说明:
⚠️ 注意事项:
该方法结构清晰、容错性强,适用于任意数量的搜索项与标准CSV格式,是生产环境中推荐的实践模式。