Python编程案例:招生档案按省份/地区归档
真实案例,某大学招生办职员收到了全国各地区的学生资料,存在/Users/liuxiaowei/学生资料下。每个学生资料以他们的姓名命名,例如:李小龙.docx。现在需要把这些学生资料按照他们的省份/地区进行分类,以便之后发给对应地区的负责人。分类的文件夹需要创建再/Users/liuxiaowei/学生资料这个路径下,例如:/Users/liuxiaowei/学生资料/吉林。每个学生分别属于那个地区的信息在“学生地区.xlsx”这个Excel表格中。如下图:
运行环境:
OS:macOS Version 12.3.1
IDE: PyCharm 2020.1
利用Python实现创建文件夹和自动归档。编程思路如下:
§ 读取地区表中的每行数据中的省份/地区,在学生资料文件夹下创建“省份/地区”文件夹
§ 遍历学生资料文件夹下的所有文件并提取文件名(姓名)
§ 判断地区表中的姓名数据与学生资料文件夹下的文件名是否相等
§ 如果相等, 合并路径和文件并移动到对应的“省份/地区”文件夹下
源码如下:
#_*_coding:utf-8_*_
# 作者 :liuxiaowei
# 创建时间 :4/9/22 3:32 PM
# 文件 :夜曲大学招生办.py
# IDE :PyCharm
import os
import openpyxl
import shutil
# 工作路径赋值给workPath
workPath = '/Users/liuxiaowei/Wendy'
# 指定当前工作路径为workPath
os.chdir(workPath)
# 打开学生地区工作簿
wb = openpyxl.load_workbook('学生地区.xlsx')
# 读取学生地区工作簿里的地区表数据,根据学生对应的省份/地区创建对应的文件夹
for rowData in wb['地区表'].rows:
# 因为表格表头是'省份/地区',所以要过滤掉
if rowData[1].value == '省份/地区':
continue
# 在学生资料文件夹下再建立省份/地区文件夹
provPath = os.path.join('学生资料', rowData[1].value)
if not os.path.exists(provPath):
os.mkdir(provPath)
# 遍历学生资料文件夹下的所有学生文件
for stu_doc in os.listdir('学生资料'):
# 因为表格表头是'姓名',所以要过滤掉
if rowData[0].value == '姓名':
continue
# 如果表格里的学生姓名与学生命名的文件名相等,移动该文件到相应的省份/地区文件夹
if rowData[0].value == stu_doc.split('.')[0]:
# 合并相对路径和学生文件
stu_doc_path = os.path.join('学生资料', stu_doc)
# 移动文件到目的目录
shutil.move(stu_doc_path, provPath)
运行结果如下: