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

相关文章
|
2天前
|
Python
不容错过!Python中图的精妙表示与高效遍历策略,提升你的编程艺术感
本文介绍了Python中图的表示方法及遍历策略。图可通过邻接表或邻接矩阵表示,前者节省空间适合稀疏图,后者便于检查连接但占用更多空间。文章详细展示了邻接表和邻接矩阵的实现,并讲解了深度优先搜索(DFS)和广度优先搜索(BFS)的遍历方法,帮助读者掌握图的基本操作和应用技巧。
14 4
|
2天前
|
设计模式 程序员 数据处理
编程之旅:探索Python中的装饰器
【10月更文挑战第34天】在编程的海洋中,Python这艘航船以其简洁优雅著称。其中,装饰器作为一项高级特性,如同船上的风帆,让代码更加灵活和强大。本文将带你领略装饰器的奥秘,从基础概念到实际应用,一起感受编程之美。
|
4天前
|
存储 人工智能 数据挖掘
从零起步,揭秘Python编程如何带你从新手村迈向高手殿堂
【10月更文挑战第32天】Python,诞生于1991年的高级编程语言,以其简洁明了的语法成为众多程序员的入门首选。从基础的变量类型、控制流到列表、字典等数据结构,再到函数定义与调用及面向对象编程,Python提供了丰富的功能和强大的库支持,适用于Web开发、数据分析、人工智能等多个领域。学习Python不仅是掌握一门语言,更是加入一个充满活力的技术社区,开启探索未知世界的旅程。
15 5
|
2天前
|
机器学习/深度学习 JSON API
Python编程实战:构建一个简单的天气预报应用
Python编程实战:构建一个简单的天气预报应用
11 1
|
2天前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
18 2
|
4天前
|
人工智能 数据挖掘 开发者
探索Python编程:从基础到进阶
【10月更文挑战第32天】本文旨在通过浅显易懂的语言,带领读者从零开始学习Python编程。我们将一起探索Python的基础语法,了解如何编写简单的程序,并逐步深入到更复杂的编程概念。文章将通过实际的代码示例,帮助读者加深理解,并在结尾处提供练习题以巩固所学知识。无论你是编程新手还是希望提升编程技能的开发者,这篇文章都将为你的学习之旅提供宝贵的指导和启发。
|
1天前
|
分布式计算 并行计算 大数据
Python编程中的高效数据处理技巧
Python编程中的高效数据处理技巧
7 0
|
3天前
|
SQL 数据挖掘 Python
数据分析编程:SQL,Python or SPL?
数据分析编程用什么,SQL、python or SPL?话不多说,直接上代码,对比明显,明眼人一看就明了:本案例涵盖五个数据分析任务:1) 计算用户会话次数;2) 球员连续得分分析;3) 连续三天活跃用户数统计;4) 新用户次日留存率计算;5) 股价涨跌幅分析。每个任务基于相应数据表进行处理和计算。
|
3天前
|
机器学习/深度学习 人工智能 数据可视化
探索Python编程:从基础到高级
【10月更文挑战第33天】本文是一篇深入浅出的Python编程入门教程,适合初学者阅读。文章首先介绍了Python的基本概念和语法,然后通过实例讲解了如何使用Python进行数据处理和分析,最后介绍了一些高级特性和库,帮助读者更好地掌握Python编程。无论你是编程新手还是有一定经验的开发者,这篇文章都能给你带来新的启示和收获。
|
4天前
|
存储 人工智能 数据挖掘
探索Python编程的奥秘
【10月更文挑战第32天】在这篇文章中,我们将一起踏上一段奇妙的Python编程之旅。从基础语法到高级特性,我们将通过一系列简单而直观的代码示例,逐步揭开Python语言背后的神秘面纱。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和深入的理解。让我们一起开始这段旅程吧!
下一篇
无影云桌面