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

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

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

image.png

运行环境:

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)

运行结果如下:

image.png

相关文章
|
9月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
1529 102
|
9月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
493 104
|
9月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
387 103
|
9月前
|
机器学习/深度学习 人工智能 数据挖掘
Python:现代编程的首选语言
Python:现代编程的首选语言
406 82
|
8月前
|
数据采集 监控 数据库
Python异步编程实战:爬虫案例
🌟 蒋星熠Jaxonic,代码为舟的星际旅人。从回调地狱到async/await协程天堂,亲历Python异步编程演进。分享高性能爬虫、数据库异步操作、限流监控等实战经验,助你驾驭并发,在二进制星河中谱写极客诗篇。
Python异步编程实战:爬虫案例
|
8月前
|
Python
Python编程:运算符详解
本文全面详解Python各类运算符,涵盖算术、比较、逻辑、赋值、位、身份、成员运算符及优先级规则,结合实例代码与运行结果,助你深入掌握Python运算符的使用方法与应用场景。
511 3
|
8月前
|
数据处理 Python
Python编程:类型转换与输入输出
本教程介绍Python中输入输出与类型转换的基础知识,涵盖input()和print()的使用,int()、float()等类型转换方法,并通过综合示例演示数据处理、错误处理及格式化输出,助你掌握核心编程技能。
733 3
|
8月前
|
并行计算 安全 计算机视觉
Python多进程编程:用multiprocessing突破GIL限制
Python中GIL限制多线程性能,尤其在CPU密集型任务中。`multiprocessing`模块通过创建独立进程,绕过GIL,实现真正的并行计算。它支持进程池、队列、管道、共享内存和同步机制,适用于科学计算、图像处理等场景。相比多线程,多进程更适合利用多核优势,虽有较高内存开销,但能显著提升性能。合理使用进程池与通信机制,可最大化效率。
549 3
|
8月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
757 0
|
9月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的多面手
Python:现代编程的多面手
445 0

推荐镜像

更多