Python编程案例:招生档案按省份/地区归档


真实案例,某大学招生办职员收到了全国各地区的学生资料,存在/Users/liuxiaowei/学生资料下。每个学生资料以他们的姓名命名,例如:李小龙.docx。现在需要把这些学生资料按照他们的省份/地区进行分类,以便之后发给对应地区的负责人。分类的文件夹需要创建再/Users/liuxiaowei/学生资料这个路径下,例如:/Users/liuxiaowei/学生资料/吉林。每个学生分别属于那个地区的信息在“学生地区.xlsx”这个Excel表格中。如下图:

python获取省市县名称 python利用省份简称匹配省份_python

运行环境:

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)

运行结果如下:

python获取省市县名称 python利用省份简称匹配省份_os模块_02