【办公类-19-01】20240108图书统计登记表制作(23个班级)EXCEL复制表格并合并表格

news2024/11/20 14:24:10

背景需求:

制作一个EXCEL模板,每个班级的班主任统计 班级图书量(一个孩子10本,最多35个孩子350本)

EXCEL模板

1.0版本:

将这个模板制作N份——每班一份

'
项目:班级图书统计表
核心:一个EXCEL模板批量生成N个班级的表格,然后合在一个EXCEL内变成N个工作簿(便于了解各班情况)+合并为1个工作簿(便于对数目名称分类统计)
作者:阿夏
时间:2024年1月8日19:03'''

#导入模块xlrd
import xlrd
import openpyxl
import pandas as pd
import os
import time
# 先在桌面上建立一个“图书”的文件夹,里面做一个EXCEL基础模板

# 在图书文件夹里新建一个“整理”的文件夹
imagePath=r'C:\Users\jg2yXRZ\OneDrive\桌面\图书'
imagePath2=imagePath+'/整理'
# 反斜杠
if not os.path.exists(imagePath2):  # 判断存放图片的文件夹是否存在
    os.makedirs(imagePath2)  # 若图片文件夹不存在就创建

# 班级名称(用遍历,就不用每次都写长串的列表了
classroom=[]
for  a in ['托']:
    for b in range(1,3):        # 托班两个
        classroom.append('{}{}班'.format(a,b))

for  c in ['小','中','大']:
    for d in range(1,8):        # 小中大都是7个班 
        #  如果要用“一、二、三班”汉字表示,就是for  d in ['一 ','二','三'】但是这种情况下 小一班前面要加0101,否则汉字拼音会让排序混乱
        bj='{}{}班'.format(c,d)
        # 如果某个年级没有6班,就跳过,本学期班级号都是连贯的
        # if bj=='中6班':
        #     pass
        # else:
        #     classroom.append(bj)
        classroom.append(bj)
print(classroom)
print(len(classroom))


# 打开EXCEL文件,修改标题,并保存

for x in range(len(classroom)):  
    #打开工作表模板
    wb = openpyxl.load_workbook(imagePath+r'/(模板)大1班班级图书汇总表.xlsx')
 
    # EXCEL模板里面只有一个工作簿
    sheet = wb['Sheet1']
    # 在第一行里写入新的标题(模板里面的字体字号已居中经确定,所以不用再考虑这些,直接写入文字即可)
    sheet['A1']='XX幼儿园  {} 班级图书汇总表'.format(classroom[x])
    # 另存为
    wb.save(imagePath2+r'/{}班级图书汇总表.xlsx'.format(classroom[x]))
    wb.close()
# EXCEL模板不能有页眉页脚

2.0版本:

后来我了解班主任已经用Word将书名进行统计(确保一页A4)打印,所以,我将23份汇总表合并在一起,做成共享编辑,班主任们用电脑打开共享文档,把Word里面的内容批量复制进去即可

(复制后格式边框可能会消失,但是由于在一个Excel,可以批量全选标签,批量统一制作每页的格式)

'''
项目:班级图书统计表
核心:一个EXCEL模板批量生成N个班级的表格,然后合在一个EXCEL内变成N个工作簿(便于了解各班情况)+合并为1个工作簿(便于对数目名称分类统计)
作者:阿夏
时间:2024年1月8日19:03'''

#导入模块xlrd
import xlrd
import openpyxl
import pandas as pd
import os
import time
# 先在桌面上建立一个“图书”的文件夹,里面做一个EXCEL基础模板

# 在图书文件夹里新建一个“整理”的文件夹
imagePath=r'C:\Users\jg2yXRZ\OneDrive\桌面\图书'
imagePath2=imagePath+'/整理'
# 反斜杠
if not os.path.exists(imagePath2):  # 判断存放图片的文件夹是否存在
    os.makedirs(imagePath2)  # 若图片文件夹不存在就创建

# 班级名称(用遍历,就不用每次都写长串的列表了
classroom=[]
for  a in ['托']:
    for b in range(1,3):        # 托班两个
        classroom.append('{}{}班'.format(a,b))

for  c in ['小','中','大']:
    for d in range(1,8):        # 小中大都是7个班 
        #  如果要用“一、二、三班”汉字表示,就是for  d in ['一 ','二','三'】但是这种情况下 小一班前面要加0101,否则汉字拼音会让排序混乱
        bj='{}{}班'.format(c,d)
        # 如果某个年级没有6班,就跳过,本学期班级号都是连贯的
        # if bj=='中6班':
        #     pass
        # else:
        #     classroom.append(bj)
        classroom.append(bj)
print(classroom)
print(len(classroom))


# 打开EXCEL文件,修改标题,并保存

for x in range(len(classroom)):  
    #打开工作表模板
    wb = openpyxl.load_workbook(imagePath+r'/(模板)大1班班级图书汇总表.xlsx')
 
    # EXCEL模板里面只有一个工作簿
    sheet = wb['Sheet1']
    # 在第一行里写入新的标题(模板里面的字体字号已居中经确定,所以不用再考虑这些,直接写入文字即可)
    sheet['A1']='XX幼儿园  {} 班级图书汇总表'.format(classroom[x])
    # 另存为
    wb.save(imagePath2+r'/{}班级图书汇总表.xlsx'.format(classroom[x]))
    wb.close()
# EXCEL模板不能有页眉页脚
time.sleep(2)
# # 把整理里面的多个EXCEL工作表合并在一个工作表内N个工作簿、


# 获取"整理"目录下所有的表
gzb = os.listdir(imagePath2)
print(gzb)

with pd.ExcelWriter(imagePath+r'/XX幼儿园{}个班级 班级图书汇总表合.xlsx'.format(len(classroom))) as writer:
# 	# 循环遍历表格
    for i in gzb:
        # 拼接每个文件的路径
        file_path = imagePath2+ '/' + i
        # 工作簿表名=文件名称的前3个元素“大X班”
        sheet_name = i[:3]
        df = pd.read_excel(file_path)

		#变相解决表格中第一行第一列为空的缺陷
        string = "".join(list(str(i) for i in df.index))
        # 判断如果索引都为数字,则不保留索引(根据自己代码调整)
        if string.isdigit():
            df.to_excel(writer, sheet_name,index=False)
        else:
            df.to_excel(writer, sheet_name)

存在问题:

把所有工作表放在一个工作表的不同工作簿里,原来的格式不见了

暂时处理方式:

全选标签。统一修改格式

发到手机里,转成编辑模式共享。

使用情况:

给领导发了两个版本:

最后领导觉得还是打包发送方便,所以就是每个班级填一份,组长收齐。

思考:

我更喜欢第二款共享编辑模式制作汇总表格,但是格式消失,人工批量改格式还是比较繁琐的,但是目前测试的几个代码都不能复制格式,后续一定能找到直接复制表格样式的代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1370940.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

合宙海外模组硬核出击,Air780UAAir780UU全新上市

简介 随着国内市场竞争日趋激烈,企业产品出海已呈如火如荼之势,向外发展拼商机更需硬核优势。 合宙作为物联网行业的核心器件提供商,将逐步推出系列高性价比海外模组,全面助力行业客户出海。现针对亚太、欧洲地区,全…

ChatGPT知名开源项目有哪些

ChatGPT-Next-Web:基于ChatGPT API的私有化部署网页聊天系统 主要功能: 只需在 1 分钟内即可在 Vercel 上一键免费部署,支持私有服务器快速部署,支持使用私有域名支持ChatGPT3.5、4等常见模型Linux/Windows/MacOS 上的紧凑型客户…

【Java】知识——各类编码格式以及样例

一、 #ASCII 码 计算机内所有的信息都是二进制位。一个字节包含 8 个二进制位,可以表示 256 个状态,每个状态表示一个符号。 ASCII 码一共规定了128个字符的编码,比如空格 SPACE 是32(二进制00100000),大写…

Shopee买家通系统:轻松获取虾皮买手号的智能利器

近来,有一款强大的软件引起了广泛关注,它就是Shopee买家通系统,为用户提供了自动化注册虾皮买手号的便捷途径。目前,该软件已覆盖菲律宾、泰国、马来西亚、越南、巴西、印度尼西亚等多个国家,为用户提供更广泛的服务。…

CUTANA™ pAG-Tn5 for CUTTag

CUTANA pAG-Tn5是靶向剪切及转座酶(CUT&Tag)技术中进行高效绘制染色质特征的关键试剂。与ChIP-seq相比,CUT&Tag在降低细胞需求量和测序深度的信噪比方面进行了显著改进。CUTANA pAG-Tn5是一种高活性的E. coli转座酶突变体(Tn5)与蛋白A/G的融合产物&#xff…

龍运当头--html做一个中国火龙祝大家龙年大吉

🐉效果展示 🐉HTML展示 <body> <!-- partial:index.partial.html --> <svg><defs><g id=

怎么选择数据安全交换系统,能够防止内部员工泄露数据?

数据泄露可能给企业带来诸多风险&#xff1a;财产损失、身份盗窃、骚扰和诈骗、经济利益受损、客户信任度下降、法律风险和责任等&#xff0c;《2021年度数据泄漏态势分析报告》中显示&#xff0c;在数据泄露的主体中&#xff0c;内部人员导致的数据泄漏事件占比接近60%。 员工…

ECMAScript6历史-前端开发+ECMAScript+基础语法+入门教程

ECMAScript6详解 ECMAScript 历史 我们首先来看 ECMA 是什么。ECMA&#xff0c;读音类似“埃科妈”&#xff0c;是欧洲计算机制造商协会&#xff08;European Computer Manufacturers Association&#xff09;的简称&#xff0c;是一家国际性会员制度的信息和电信标准组织。19…

FCRP第一题详解一

先看效果: 20240106-094943 看他的第一要求: 1.整个模板只能出现一个数据集,下拉复选框与报表主体共用一个数据集,且不影响互相显示。 所以这里不能通过SQL语句来过滤,SQL语句中中只能全部查询出来,这样保证了下拉框的数据是全部,单元格里的数据只能通过数据列过滤来实…

回归预测 | Matlab实现DE-BP差分算法优化BP神经网络多变量回归预测

回归预测 | Matlab实现DE-BP差分算法优化BP神经网络多变量回归预测 目录 回归预测 | Matlab实现DE-BP差分算法优化BP神经网络多变量回归预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现DE-BP差分算法优化BP神经网络多变量回归预测&#xff08;完整源码和…

openssl3.2 - 自己构建openssl.exe的VS工程(在编译完的源码版本上)

文章目录 openssl3.2 - 自己构建openssl.exe的VS工程(在编译完的源码版本上)概述笔记备注END openssl3.2 - 自己构建openssl.exe的VS工程(在编译完的源码版本上) 概述 将openssl3.2编译出来了(openssl3.2 - 编译) 安装后的openssl.exe可以干openssl3.2所有的事情, 用openssl.…

Java缓冲字符流

PrintWriter的自动行刷新功能 如果实例化PW时第一个参数传入的是一个流&#xff0c;则此时可以再传入一个boolean型的参数&#xff0c;此值为true时就打开了自动行刷新功能。 即: 每当我们用PW的println方法写出一行字符串后会自动flush. package io; ​ import java.io.*; i…

[Docker] Mac M1系列芯片上完美运行Docker

docker pull qinchz/dm8-arm64 container_name: dm8ports:- "5236:5236"mem_limit: 1gmemswap_limit: 1gvolumes:- /data/dm8:/home/dmdba/data 数据库实例参数已修改&#xff0c;接近oracle使用习惯 #字符集 utf-8 CHARSET1 #VARCHAR 类型对象的长度以字符为单位 …

工程监测领域振弦采集仪的数据处理与分析方法探讨

工程监测领域振弦采集仪的数据处理与分析方法探讨 在工程监测领域&#xff0c;振弦采集仪是常用的一种设备&#xff0c;用于测量和记录结构物的振动数据。数据处理和分析是使用振弦采集仪得到的数据的重要环节&#xff0c;可以帮助工程师了解结构物的振动特性&#xff0c;评估…

C++信息学奥赛1087:级数求和

#include<bits/stdc.h> using namespace std; int main() {int k;cin>>k; // 从标准输入获取一个整数kdouble sum0; // 初始化sum变量为0&#xff0c;用于存储累加的和int i; // 初始化循环变量ifor(i1;;i){ // 无限循环&#xff0c;直到满足条件时跳出循环sum(dou…

C#,字符串匹配(模式搜索)KMP算法的源代码与数据可视化

D.E.Knuth J.H.Morris 一、KMP算法 KMP 算法&#xff08;Knuth-Morris-Pratt 算法&#xff09;是其中一个著名的、传统的字符串匹配算法&#xff0c;效率比较高。 KMP算法由D.E.Knuth&#xff0c;J.H.Morris和V.R.Pratt在 Brute-Force算法的基础上提出的模式匹配的改进算法。…

CDN加速之HTTPS配置

记录一下HTTPS配置的免费证书配置 2张图搞定 最后补充说明&#xff1a; 由于CDN采用的Tengine服务基于Nginx&#xff0c;因此开启HTTPS安全加速功能的加速域名&#xff0c;只支持上传Nginx能读取的PEM格式的证书。如果证书不是PEM格式&#xff0c;需转换成PEM格式。转换方法&a…

巧用 G5g 畅游Android流媒体游戏

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; 巧用 G5g 畅游Android流媒体游戏 概览 Amazon EC2 G5g 实例由 AWS Graviton2 处理器提供支持&#xff0c;并配备 NVIDIA T4G Tensor Core GPU&#xff0c;可为 Andro…

SAP SMARTFORMS 打印表换行

表单打印自动换行&#xff0c;值的拼接 cl_abap_char_utilities>cr_lfSMARTFORMS 设置 程序传值处理 TYPES: BEGIN OF ty_c, zm_zd TYPE char25, END OF ty_c. DATA: lt_ty1 TYPE TABLE OF ty_c, lt_ty2 TYPE TABLE OF ty_c, ls_t…

重新认识canvas,掌握必要的联结密码

查看专栏目录 canvas示例教程100专栏&#xff0c;提供canvas的基础知识&#xff0c;高级动画&#xff0c;相关应用扩展等信息。canvas作为html的一部分&#xff0c;是图像图标地图可视化的一个重要的基础&#xff0c;学好了canvas&#xff0c;在其他的一些应用上将会起到非常重…