Python根据图片生成学生excel成绩表

学习笔记:

上完整代码

复制代码
import os
import re
from openpyxl import Workbook, load_workbook
from openpyxl.drawing.image import Image as ExcelImage
from PIL import Image as PilImage

# 定义图片路径和Excel文件路径
image_dir = './resources/stupics'  # 图片所在的文件夹路径,请根据实际情况修改
excel_path = './result/students_info.xlsx'  # Excel文件路径,请根据实际情况修改
output_folder = './result';
if not os.path.exists(output_folder):
    os.makedirs(output_folder)

# 定义图片名称格式的正则表达式
pattern = r'(?P<grade>\d{2})级(?P<major>[\u4e00-\u9fff]+)(?P<class>\d+班)(?P<name>[\u4e00-\u9fff]+)'

# 获取图片文件列表
image_files = [f for f in os.listdir(image_dir) if f.endswith(('.png', '.jpg', '.jpeg'))]

# 检查是否存在Excel文件,若不存在则创建新文件
if not os.path.exists(excel_path):
    wb = Workbook()
    ws = wb.active
    ws.title = "学生信息"
    # 写入表头
    headers = ["年级", "专业", "班级", "姓名", "照片"]
    ws.append(headers)
else:
    wb = load_workbook(excel_path)
    ws = wb.active

# 定义各列的固定宽度
column_widths = {
    'A': 10,  # 年级
    'B': 25,  # 专业
    'C': 8,   # 班级
    'D': 15,  # 姓名
    'E': 15   # 照片
}

# 应用固定列宽
for column, width in column_widths.items():
    ws.column_dimensions[column].width = width

# 遍历图片文件,解析名称并写入Excel
for image_file in image_files:
    match = re.match(pattern, os.path.splitext(image_file)[0])
    if match:
        info = match.groupdict()
        row = [
            info['grade'] + '级',
            info['major'],
            info['class'],
            info['name']
        ]
        ws.append(row)

        # 确保图片插入到正确的行
        img_path = os.path.join(image_dir, image_file)
        img = PilImage.open(img_path)
        excel_img = ExcelImage(img_path)
        excel_img.width, excel_img.height = 80, 110  # 根据需要调整图片大小

        # 计算图片宽度对应的字符数
        pixel_width = excel_img.width
        char_width = pixel_width / 7  # 假设每个字符约等于7个像素

        # 设置图片所在列的宽度
        cell_location = f'E{ws.max_row}'  # 使用当前最大行数作为图片插入位置
        ws.add_image(excel_img, cell_location)
        ws.column_dimensions['E'].width = char_width

        # 计算行高(假设每点约等于1.33像素)
        pixel_height = excel_img.height
        point_height = pixel_height / 1.33

        # 设置行高
        ws.row_dimensions[ws.max_row].height = point_height

# 保存工作簿
wb.save(excel_path)
print("数据已成功写入Excel文件")

这是结构

运行结果及其展示

免费,需要q

相关推荐
想用offer打牌1 分钟前
面试官问:Redis和MySQL数据一致,为什么还需要MySQL?🤠
数据库·redis·mysql
M1A111 分钟前
Python数据结构操作:全面解析与实践
后端·python
扑克中的黑桃A16 分钟前
Python-打印杨辉三角
python
搬码红绿灯42 分钟前
MySQL主从复制深度解析:原理、架构与实战部署指南
数据库·mysql·架构
程序员三藏1 小时前
如何使用Jmeter进行压力测试?
自动化测试·软件测试·python·测试工具·jmeter·测试用例·压力测试
carpell1 小时前
【语义分割专栏】3:Segnet原理篇
人工智能·python·深度学习·计算机视觉·语义分割
24K纯学渣1 小时前
Python编码格式化之PEP8编码规范
开发语言·ide·python·pycharm
怒视天下1 小时前
零基础玩转Python生物信息学:数据分析与算法实现
开发语言·python
zhanshuo2 小时前
Python元组黑科技:3招让数据安全暴增200%,学生管理系统实战揭秘!
python
空中湖2 小时前
免费批量图片格式转换工具
图像处理·python·程序人生