当前位置: 首页 > article >正文

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


http://www.kler.cn/a/507949.html

相关文章:

  • 精选算法合集
  • 【NextJS】PostgreSQL 遇上 Prisma ORM
  • 使用 Java 实现基于 DFA 算法的敏感词检测
  • SUN的J2EE与微软的DNA
  • 持续集成 01|Gitee介绍、Pycharm使用Gitee
  • ASP.NET Core - .NET 6 以上版本的入口文件
  • [创业之路-254]:《华为数字化转型之道》-1-华为是一个由客户需求牵引、高度数字化、高度智能化、由无数个闭环流程组成的价值创造、评估、分配系统。
  • 学习微信小程序的下拉列表控件-picker
  • NC65增加按钮打开其他单据
  • DX12 快速教程(3) —— 画矩形
  • Java 数据结构 队列之双端队列 常用方法 示例代码 及其实现
  • vue+arcgis api for js实现地图经纬网格显示
  • 大模型WebUI:Gradio全解11——Chatbot:融合大模型的多模态聊天机器人(6)
  • Qt 使用共享内存的方式限制程序单一启动
  • 深入内核讲明白Android Binder【二】
  • 【JVM-8】使用 IBM Thread and Monitor Dump Analyzer for Java (TMDA) 分析线程转储
  • 深入了解卷积神经网络(CNN):图像处理与深度学习的革命性技术
  • 修复5.0.0r 64位版本浏览器和一些库找不到的问题
  • Flink (九):DataStream API (六) Process Function
  • 如何在 Google Cloud Shell 中使用 Visual Studio Code (VS Code)?
  • Spring Boot与MyBatis
  • FPGA:Quartus软件与操作系统版本对照表
  • Java 开发常见面试题3
  • ORB-SLAM2源码学习: Frame.cc: cv::Mat Frame::UnprojectStereo将某个特征点反投影到三维世界坐标系中
  • “云计算+中职”:VR虚拟仿真实训室的发展前景
  • VS2022——WPF初始化和控件Nmae虚假报错