当前位置: 首页 > news >正文

按照文本每行匹配文件复制到指定位置

1

  • 从指定的 TXT 文件(txt_file)中读取若干关键字(去重并按字典序排序)。

  • 在给定的源目录(source_dir)及其子目录中,查找文件名包含某关键字的第一个文件。

  • 将该文件移动到目标目录(target_dir),并在遇到重名时自动添加后缀 _1, _2… 以免覆盖。

  • 控制台实时输出每个关键字的匹配与移动结果,最后汇总共多少关键字、成功移动多少个文件。

1

假设目录与文件如下:

H:\
├─ data
│   ├─ report1.txt
│   ├─ image_fail.png
│   └─ sub
│       └─ test_error.log
├─ list.txt
└─ copy    (初始为空)

list.txt 内容(每行一个关键字)

report
fail
missing
error

运行控制台输出

✔ 已移动: 'report1.txt' 对应关键字 'report' 到 'H:\copy\report1.txt'
✔ 已移动: 'image_fail.png' 对应关键字 'fail' 到 'H:\copy\image_fail.png'
⚠ 未找到匹配文件 for key: 'missing'
✔ 已移动: 'test_error.log' 对应关键字 'error' 到 'H:\copy\test_error.log'共 4 个关键字,成功移动 3 个,对应文件。未移动 1 个。

执行后目录结构

H:\
├─ data
│   └─ sub
│       └─               (原 test_error.log 已移动)
├─ copy
│   ├─ report1.txt
│   ├─ image_fail.png
│   └─ test_error.log
├─ list.txt

import os
import shutildef move_files_from_txt(txt_file, source_dir, target_dir):"""仅移动文件名中包含 TXT 文件中任意一行关键字的文件。如果某关键字未匹配任何文件,会在控制台报告。"""# 创建目标目录os.makedirs(target_dir, exist_ok=True)# 读取并去重 TXT 关键字with open(txt_file, 'r', encoding='utf-8') as f:keys = sorted({line.strip() for line in f if line.strip()})moved_keys = set()# 对每个关键字,查找并移动第一个匹配的文件for key in keys:found = Falsefor root, _, files in os.walk(source_dir):for fname in files:if key in fname:# 构造路径src = os.path.join(root, fname)dst = os.path.join(target_dir, fname)# 处理重名if os.path.exists(dst):base, ext = os.path.splitext(fname)i = 1while os.path.exists(os.path.join(target_dir, f"{base}_{i}{ext}")):i += 1dst = os.path.join(target_dir, f"{base}_{i}{ext}")# 移动shutil.move(src, dst)print(f"✔ 已移动: '{fname}' 对应关键字 '{key}' 到 '{dst}'")moved_keys.add(key)found = Truebreakif found:breakif not found:print(f"⚠ 未找到匹配文件 for key: '{key}'")total = len(keys)success = len(moved_keys)print(f"\n共 {total} 个关键字,成功移动 {success} 个,对应文件。未移动 {total - success} 个。")# 示例使用
if __name__ == '__main__':txt_file = r"H:\list.txt"source_directory = r"H:\data"target_directory = r"H:\copy"move_files_from_txt(txt_file, source_directory, target_directory)

1

http://www.xdnf.cn/news/108703.html

相关文章:

  • CONDA:用于 Co-Salient 目标检测的压缩深度关联学习(总结)
  • 开源 RAG 引擎:文档理解精准、检索高效、可视化干预灵活,一站式搞定
  • Kappa架构:简化大数据实时流处理的创新方案
  • 【Luogu】动态规划二
  • 2025.4.27机器学习笔记:文献阅读
  • 类和对象(中)
  • Spring AI 会话记忆(笔记)
  • 【3.2】pod详解—— Pod的相位(phase)状态(status)
  • Linux常用指令
  • 小刚说C语言刷题——1338求圆环的面积
  • C++二分法详解
  • el-table 目录树列表本地实现模糊查询
  • Linux部署Redis主从
  • 天梯-零头就抹了吧
  • 实操Obsidian+Ollama+deepseek构建本地知识库
  • C语言五子棋项目
  • [计算机科学#1]:计算机的前世今生,从算盘到IBM的演变之路
  • flex布局说明
  • 百万点数组下memset、memcpy与for循环效率对比及原理分析
  • 经典算法 小数点后的第n位
  • 语音合成之四基于LLM的语音合成
  • Sql刷题日志(day5)
  • JVM理解(通俗易懂)
  • 2025年渗透测试面试题总结-拷打题库14(题目+回答)
  • 时间自动填写——电子表格公式的遗憾(DeepSeek)
  • A13 自定义系统服务使用总结
  • Kafka集群
  • ABP-Book Store Application中文讲解 - Part 0:开发环境搭建
  • 意见反馈留言二维码制作
  • leetcode-枚举