Python办公自动化实例--照片挑选

实例背景

学院举行毕业晚会,要制作照片墙,让学生自己上传一直没有多少回应,上传的没有几张(学院的号召力是真的拉),需要从整个学校的学生证件照中挑选出外面学院的同学,于是这个"艰巨"的任务就落到了我这个牛马身上。。

由于证件照涉及个人的信息这里就不贴出来了,我拥有的材料:这个学校今年毕业的所有同学的证件照,我们学院的学生名单Excel,如下图:

每张图片的命名包含学生的姓名,任务的目标是通过学生的名单从整个学校的照片中挑选出我们学院的学生的照片到另一个文件夹中。

解决思路

辅导员让我根据名单中的名字从整个学校的照片中一个一个剪切粘贴到另一个文件夹,从八千多的照片中挑选出三百多张学生的照片,真正的牛马产生了!(最后照片墙的制作致谢中也没有写我的名字)不过幸好可以写脚本,半个小时就能解决。

通过pandas读取我们学院每个同学的名字,再根据名字确认照片,然后在把它转移到目标的文件夹中,即可解决问题。

图片的命名格式:

xxx(姓名)-xxxxxxxxxxxxxxxx(编号)

可以对'-'使用split进行分割,返回列表后去下标为0的内容即可获得学生姓名。

代码

python 复制代码
import os
import shutil
import pandas as pd

photo_path = r'D:\py-code\company\6_11_campus\五山校区'
data_path = r'D:\py-code\company\6_11_campus\name.xlsx'

photo_student_name = []
name_namefile = {}

photo_list_file_name = sorted(os.listdir(photo_path))
for single_name in photo_list_file_name:
    photo_student_name.append(single_name.split('-')[0])
    name_namefile[single_name.split('-')[0]] = single_name

# print(len(photo_list_file_name))
# print(photo_student_name)

# print(name_namefile)
data = pd.read_excel(data_path)

au_names = data['姓名']

# 多重循环,时间复杂度高
# for name in au_names:
#     for k,v in name_namefile.items():
#         if name == k:
#             shutil.move(os.path.join(r'D:\py-code\company\6_11_campus\五山校区',v),os.path.join(r'D:\py-code\company\6_11_campus\auto',v))
    
for name in au_names:
    if name in name_namefile.keys():
        namefile = name_namefile[name]
        shutil.move(os.path.join(r'D:\py-code\company\6_11_campus\五山校区',namefile),os.path.join(r'D:\py-code\company\6_11_campus\auto',namefile))

print('done')

检查

我们学院有312个学生,但最后挑选出来只有302个,又写了一个脚本进行check

python 复制代码
import os
import shutil
from collections import defaultdict
import pandas as pd

photo_path = r'D:\py-code\company\6_11_campus\五山校区'
data_path = r'D:\py-code\company\6_11_campus\name.xlsx'

photo_student_name = []
name_namefile = defaultdict(str)

photo_list_file_name = sorted(os.listdir(photo_path))
all_name_list = []
# print(photo_list_file_name)
n=0
for single_name in photo_list_file_name:
    photo_student_name.append(single_name.split('-')[0])
    if single_name.split('-')[0] not in name_namefile:
        name_namefile[single_name.split('-')[0]] = single_name
        all_name_list.append(single_name.split('-')[0])
    else:
        # print('重复')
        # print(single_name)
        n+=1
print(n)
# print(len(photo_list_file_name))
# print(photo_student_name)


print(len(name_namefile))
data = pd.read_excel(data_path)

au_names = data['姓名']
# print(len(au_names))

for au_name in au_names:
    if au_name not in all_name_list:
        print(au_name)

发现整个学校有24个重名的,不过不是这个错误,最后的是发现有10个同学没有在学校的照片中,辅导员说不管了,真的是办事效率高的辅导员老师!

欢迎大家讨论交流~


相关推荐
球求了16 分钟前
C++:继承机制详解
开发语言·c++·学习
weixin_贾29 分钟前
最新AI-Python机器学习与深度学习技术在植被参数反演中的核心技术应用
python·机器学习·植被参数·遥感反演
张槊哲38 分钟前
函数的定义与使用(python)
开发语言·python
船长@Quant43 分钟前
文档构建:Sphinx全面使用指南 — 实战篇
python·markdown·sphinx·文档构建
北辰浮光1 小时前
[Mybatis-plus]
java·开发语言·mybatis
光而不耀@lgy1 小时前
C++初登门槛
linux·开发语言·网络·c++·后端
lkbhua莱克瓦241 小时前
用C语言实现——一个中缀表达式的计算器。支持用户输入和动画演示过程。
c语言·开发语言·数据结构·链表·学习方法·交友·计算器
Mr__Miss1 小时前
面试踩过的坑
java·开发语言
偶尔微微一笑1 小时前
AI网络渗透kali应用(gptshell)
linux·人工智能·python·自然语言处理·编辑器
啊丢_2 小时前
C++——Lambda表达式
开发语言·c++