原标题:754-批量根据excelA-B列内容移动文件到目标文件夹【带界面-源代码】
导读:
代码功能概述这段Python代码实现了一个批量根据Excel文件A、B列移动或复制文件的工具。用户可以选择源文件夹和目标文件夹,选择操作方式(复制或移动),并指定一个Exce...
代码功能概述
这段Python代码实现了一个批量根据Excel文件A、B列移动或复制文件的工具。用户可以选择源文件夹和目标文件夹,选择操作方式(复制或移动),并指定一个Excel文件。Excel文件的A列包含要处理的文件名,B列包含目标文件夹名。程序会根据这些信息将文件从源文件夹移动或复制到目标文件夹中的相应子文件夹。
功能详细说明
• 源文件夹路径:用户可以选择源文件夹路径。
• 目标文件夹路径:用户可以选择目标文件夹路径。
• 操作方式选择:用户可以选择复制或移动文件。
• Excel文件选择:程序会自动在指定目录下查找Excel文件,并读取其中的文件名和目标文件夹名。
• 批量处理:程序会根据Excel文件中的信息,将文件从源文件夹移动或复制到目标文件夹中的相应子文件夹。
• 操作控制:提供开始、停止、清空输入框和清空日志的功能。
文件夹及文件结构示例
假设我们有如下的操作设置: • 源文件夹路径:D:\SourceFolder
• 目标文件夹路径:D:\TargetFolder
• Excel文件路径:D:\excell\file_list.xlsx
Excel文件内容如下:
A列(文件名) | B列(目标文件夹名)
--------------|------------------
file1.txt | folder1
file2.jpg | folder2
file3.log | folder3
文件夹结构如下:
D:\SourceFolder
├── file1.txt
├── file2.jpg
├── file3.log
D:\TargetFolder
├── folder1
├── folder2
├── folder3
用户选择D:\SourceFolder作为源文件夹路径,D:\TargetFolder作为目标文件夹路径,操作方式为“复制”。
程序处理后,文件夹结构将变为:
D:\TargetFolder
├── folder1
│ └── file1.txt
├── folder2
│ └── file2.jpg
├── folder3
│ └── file3.log
用户操作步骤
- 启动程序:运行Python脚本,启动文件处理工具。
- 选择源文件夹路径:点击“选择文件夹”按钮,选择源文件夹路径。
- 选择目标文件夹路径:点击“选择文件夹”按钮,选择目标文件夹路径。
- 选择操作方式:选择复制或移动文件。
- 开始处理:点击“开始程序”按钮,程序将开始处理文件。
- 查看日志:程序运行过程中,可以在日志框中查看处理进度和错误信息。
- 结束任务:如果需要提前终止处理任务,可以点击“结束任务”按钮。
- 清空输入和日志:可以点击相应的按钮清空输入框和日志文本框。
代码实现细节
• 界面设计:使用tkinter
库创建图形用户界面,包括文本框、输入框、按钮等组件。
• 文件处理:使用os.walk
遍历文件夹及其子文件夹,使用shutil.move
和shutil.copy2
进行文件移动和复制。
• Excel读取:使用pandas
库读取Excel文件,获取文件名和目标文件夹名。
• 多线程:使用threading.Thread
实现文件处理的异步处理,避免界面卡顿。
• 日志记录:使用scrolledtext.ScrolledText
库创建可滚动的日志文本框,记录程序运行过程中的信息。
• 停止任务:通过全局变量stop_event
控制任务的开始和停止。
注意事项
• 确保选择的源文件夹路径和目标文件夹路径存在且有相应的读写权限。
• 确保Excel文件存在且格式正确(A列文件名,B列目标文件夹名)。
• 在批量处理文件前,建议先在小范围内测试程序,确保无误后再进行批量操作。
• 移动操作是不可逆的,请谨慎操作。
实例说明
假设我们有如下的文件夹结构:
D:\SourceFolder
├── file1.txt
├── file2.jpg
├── file3.log
D:\TargetFolder
├── folder1
├── folder2
├── folder3
Excel文件内容如下:
A列(文件名) | B列(目标文件夹名)
--------------|------------------
file1.txt | folder1
file2.jpg | folder2
file3.log | folder3
用户选择D:\SourceFolder
作为源文件夹路径,D:\TargetFolder
作为目标文件夹路径,操作方式为“复制”。
程序将按照以下步骤进行操作:
- 初始化:用户选择源文件夹路径、目标文件夹路径、操作方式后,点击“开始程序”按钮。
- 读取Excel文件:程序会读取Excel文件中的文件名和目标文件夹名。
- 遍历文件:程序会遍历源文件夹中的文件,查找与Excel文件中匹配的文件名。
- 复制文件:将找到的文件复制到目标文件夹中的相应子文件夹。
- 记录日志:程序会在日志框中记录处理进度和错误信息。
- 结束任务:如果需要提前终止处理任务,可以点击“结束任务”按钮。
- 清空输入和日志:可以点击相应的按钮清空输入框和日志文本框。
通过这种方式,用户可以方便地根据Excel文件中的信息批量移动或复制文件。
python版本:3.86
是否带UI界面:UI版本
电脑系统版本:win10 64位 专业版系统(这是测试环境,其他环境也可以32位操作系统可能需要调整代码,让AI去转换即可)
脚本使用到的库:使用pycharm编辑器,如果没有安装相关库,会自动标红提示,鼠标放到标红的地方会弹出安装库按钮
重要提示:这是源代码,需要安装python使用,也可以自行修改部分代码实现想要的功能
查看源代码
- 随机文章
- 热门文章
- 【03】铜版纸样品
- 706-批量将指定文件夹下所有文件格式后缀改为小写-UI
- 716-批量移动指定文件夹带有关键词文件到目标文件夹-支持多个关键词
- 733-批量删除指定A文件夹下包含指定关键词的文件
- 762-批量提取移动指定文件夹内所有文件包括子孙文件夹文件到指定文件夹
- 768-以文件中关键词创建文件夹并把包含该关键词的文件移动到该文件夹
- 772-批量删除文件名中某个字符前的所有内容(可选删除字符本身)
- 788-批量创建指定格式的指定数量-指定起始序列的文件夹
- 789-批量检测指定文件夹下空文件夹并输出到txt
- 搜索A文件夹内与B文件夹下快捷方式指向的最后一个文件夹同名文件夹并移动文件夹到快捷方式所在文件夹下
- 1开通VIP会员享全站内容免费查看
- 2🔥🔥🔥承接各种批处理工具定制 / 售后相关信息 / 任何需求请在该文章下留言
- 3752-批量复制文件及文件夹到多个文件夹
- 410081-1-批量解压自解压文件-【支持密码-子文件穿透】【不支持嵌套自解压或压缩包解压】-除自解压文件外不能有其他exe文件
- 5790-批量统计各文件夹下文件类型数量及文件夹路径输出到excell
- 6网页插入bilibili哔哩哔哩视频
- 7401-批量识别pdf中二维码并替换为指定图片或覆盖白色
- 8431-批量合并指定文件夹下各文件夹内pdf为一个pdf文件
- 9Adobe程序完全卸载教程完全卸载无残留-【包括单个程序卸载和全部程序卸载】(win系统版本)
- 10为ps脚本添加快捷键快速调用
还没有评论,来说两句吧...