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

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

背景需求:

制作一个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)

存在问题:

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

暂时处理方式:

全选标签。统一修改格式

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

使用情况:

给领导发了两个版本:

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

思考:

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

相关文章:

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

背景需求: 制作一个EXCEL模板,每个班级的班主任统计 班级图书量(一个孩子10本,最多35个孩子350本) EXCEL模板 1.0版本: 将这个模板制作N份——每班一份 项目:班级图书统计表 核心:一个EXCEL模板批量生成…...

spring boot 2升级为spring boot 3中数据库连接池druid的问题

目录 ConfigurationClassPostProcessor ConfigurationClassBeanDefinitionReader MybatisPlusAutoConfiguration ConditionEvaluator OnBeanCondition 总结 近期给了一个任务,要求是对现有的 spring boot 2.x 项目进行升级,由于 spring boot 2.x 版…...

客服系统配置之Nginx处理静态资源和动态请求

Nginx直接处理静态资源,接口动态请求走反向代理到后端 这样可以减轻后端服务的压力 location / {try_files $uri kefu; }location kefu {# 这里是命名位置 kefu 的配置proxy_pass http://backend-server;# 其他反向代理的配置... }如果请求的是静态资源&#xff08…...

Golang 切片

前言 在Go语言中,切片是一个引用类型,它提供了对数组的动态窗口。切片并不存储任何数据,它只是描述了底层数组中的一个片段。切片的定义包括三个部分:指向数组的指针、切片的长度和切片的容量 基本使用 声明切片:声…...

防止公司办公终端文件数据 | 资料外泄,——自动智能透明加密防泄密软件系统

天锐绿盾公司电脑文件数据资料透明加密防泄密软件系统是一款专门用于保护企业电脑文件数据安全的软件系统。它采用透明加密技术,能够在不影响员工正常工作的情况下,对电脑上的文件数据进行自动加密,从而有效防止企业数据泄密。 PC端访问地址&…...

C#-枚举

枚举类型 (enum type) 是具有一组命名常量的独特的值类型。 下面的示例声明并使用一个名为 Color 的枚举类型,该枚举具有三个常量值 Red、Green 和 Blue: using System; using System;enum Color {Red,Green,Blue }class Test {static void PrintColor(…...

Java后端开发——SSM整合实验

文章目录 Java后端开发——SSM整合实验一、常用方式整合SSM框架二、纯注解方式整合SSM框架 Java后端开发——SSM整合实验 一、常用方式整合SSM框架 1.搭建数据库环境:MySQL数据库中创建一个名称为ssm的数据库,在该数据库中创建一个名称为tb_book的表 …...

VMware虚拟机安装Ubuntu

准备:Ubuntu的镜像文件,VMware,手. 1.新建虚拟机,选择自定义,下一步。 2.硬件兼容性,选择Workstation 16.x,下一步。 3.选择安装程序光盘映像文件,路径为映像文件所在文件夹,下一步。 4. 创建用户和设置密…...

用一个简单的例子说明单细胞分析中的dgCMatrix数据的结构

dgCMatrix用来存储矩阵的一种数据格式,这种数据格式很适合存储稀疏矩阵(即矩阵中大部分值为0)。dgCMatrix使用三个数组(分别是i,p,x)来存储矩阵。怎么存的呢? 先举一个普通矩阵的例…...

【小工具】pixi-live2d-display,直接可用的live2d的交互网页/桌面应用

效果&#xff1a; <script src"https://cubism.live2d.com/sdk-web/cubismcore/live2dcubismcore.min.js"></script> <script src"https://cdn.jsdelivr.net/gh/dylanNew/live2d/webgl/Live2D/lib/live2d.min.js"></script> <…...

vulhub中的Nginx漏洞的详细解析

Nginx漏洞 1.cd到nginx_parsing_vulnerability cd /opt/vulhub/nginx/nginx_parsing_vulnerability 2.执行docker-compose up -d 3.查看靶场是否开启成功 dooker ps 4.访问浏览器 因为这里是80端口所以直接使用ip就能访问成功 5.上传图片 注意这里的图片是含有一句话木马的图…...

如何实现公网访问GeoServe Web管理界面共享空间地理信息【内网穿透】

文章目录 前言1.安装GeoServer2. windows 安装 cpolar3. 创建公网访问地址4. 公网访问Geo Servcer服务5. 固定公网HTTP地址 前言 GeoServer是OGC Web服务器规范的J2EE实现&#xff0c;利用GeoServer可以方便地发布地图数据&#xff0c;允许用户对要素数据进行更新、删除、插入…...

k8s-存储 11

一、configmapu存储 首先&#xff0c;确保集群正常&#xff0c;节点都处于就绪状态 Configmap用于保存配置数据&#xff0c;以键值对形式存储。configMap资源提供了向 Pod 注入配置数据的方法&#xff0c;旨在让镜像和配置文件解耦&#xff0c;以便实现镜像的可移植性和可复用…...

蓝牙信标定位原理

定位原理&#xff1a;蓝牙信标的定位原理是基于RSSI蓝牙信号强度来做定位的。 根据应用场景不同&#xff0c;通过RSSI定位原理可分为两种定位方式 一、存在性定位 这种方式通常要求所需定位的区域安装一个蓝牙信标即可&#xff0c;手持终端扫描蓝牙信标信号&#xff0c;扫描…...

单片机期末复习

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、单片机…...

springboot虹软人脸识别集成

准备工作 虹软开放平台中创建一个新的应用 虹软开发平台【点我跳转】 开始上代码 基本配置 将下载的jar包放到src同级目录下 <!-- 虹软--><dependency><groupId>com.arcsoft.face</groupId><artifactId>arcsoft-sdk-face</artifactI…...

Element+vue3.0 tabel合并单元格span-method

Elementvue3.0 tabel合并单元格 span-method :span-method"objectSpanMethod"详解&#xff1a; 在 objectSpanMethod 方法中&#xff0c;rowspan 和 colspan 的值通常用来定义单元格的行跨度和列跨度。 一般来说&#xff0c;rowspan 和 colspan 的值应该是大于等于…...

Python学习笔记第七十九天(OpenCV轨迹栏)

Python学习笔记第七十九天 OpenCV轨迹栏cv.createTrackbarcv.getTrackbarPos两者合并运用 后记 OpenCV轨迹栏 cv.getTrackbarPos 和 cv.createTrackbar 是 OpenCV 库中用于创建和获取跟踪条位置的函数。这些函数通常用于在视频处理或图像处理应用程序中创建用户界面&#xff0…...

uniapp自定义顶部导航并解决打包成apk后getMenuButtonBoundingClientRect方法失效问题

需求&#xff1a;要在app上的顶部导航提示哪里添加一些东西进去&#xff0c;用uniapp自带的肯定不行啊&#xff0c;所以自定义了所有的页面的顶部导航&#xff0c;之后自定义后用手机调试发现 uni.getMenuButtonBoundingClientRect()这个方法的top获取不到....网上找了很多种方…...

C++入门【26-C++ Null 指针】

在变量声明的时候&#xff0c;如果没有确切的地址可以赋值&#xff0c;为指针变量赋一个 NULL 值是一个良好的编程习惯。赋为 NULL 值的指针被称为空指针。 NULL 指针是一个定义在标准库中的值为零的常量。请看下面的程序&#xff1a; 实例 #include <iostream> using…...

Linux第14步_安装FTP服务器

安装“vim编辑器”后&#xff0c;我们紧接着“安装FTP服务器”。 1、在安装前&#xff0c;要检查虚拟机可以上网&#xff0c;否则可能会导致安装失败。 2、在虚拟机界面右击鼠标&#xff0c;弹出下面的对话框 3、点击“打开终端(E)”&#xff0c;得到下面的界面 &#xff1a;…...

Linux截图方法推荐

因为经常会遇到以图为证的情况&#xff0c;而办公设备基本都是linux,所以汇总一下常见的linux截图方式。 1&#xff1a;在 Linux 中系统集成的截图的默认方式 你想要截取整个屏幕&#xff1f;屏幕中的某个区域&#xff1f;某个特定的窗口&#xff1f; 如果只需要获取一张屏幕…...

在Gitee上维护Erpnext源

在Gitee上维护Erpnext源 官方的frappe和erpnext地址: GitHub - frappe/frappe: Low code web framework for real world applications, in Python and Javascript GitHub - frappe/erpnext: Free and Open Source Enterprise Resource Planning (ERP) 1, 仓库地址输入frappe的官…...

2024.1.9 基于 Jedis 通过 Java 客户端连接 Redis 服务器

目录 引言 RESP 协议 Redis 通信过程 实现步骤 步骤一 步骤二 步骤三 步骤四 引言 在 Redis 命令行客户端中手敲命令并不是我们日常开发中的主要形式而更多的时候是使用 Redis 的 API 来实现定制化的 Redis 客户端程序&#xff0c;进而操作 Redis 服务器即使用程序来操…...

软件测试|SQL ORDER BY排序利器使用

简介 在SQL查询语言中&#xff0c;ORDER BY子句是一项重要的功能&#xff0c;它允许我们按照指定的列或表达式对查询结果进行排序。本文将详细介绍SQL ORDER BY子句的用法、常见排序方式以及在实际应用中的应用场景。 ORDER BY子句 SQL是一种用于管理和操作关系型数据库的强…...

苹果手机IOS软件应用IPA砸壳包提取完整教程

我们有很多小伙伴可能想要获取到苹果手机软件的安装包但又不知该如何获取&#xff0c;本文就教你如何获取到IOS软件的IPA砸壳包 首先我们需要准备一台越狱的苹果IOS设备&#xff0c;如果不知如何越狱的可以参考这篇苹果手机越狱教程&#xff1a;https://www.hereitis.cn/artic…...

「 网络安全术语解读 」内容安全策略CSP详解

引言&#xff1a;什么是CSP&#xff0c;它为什么可以防御一些常见的网络攻击&#xff0c;比如XSS攻击&#xff0c;具体原理是什么&#xff1f;以及如何绕过CSP&#xff1f; 1. CSP定义 CSP&#xff08;Content Security Policy&#xff0c;内容安全策略&#xff09;是一种网络…...

Docker与微服务实战(基础篇)

Docker与微服务实战&#xff08;基础篇&#xff09; 1、Docker简介2、Docker安装步骤1.Centos7及以上的版本2.卸载旧版本3.yum安装gcc相关4.安装需要的软件包5.设置stable镜像仓库【国内aliyun】6.更新yum软件包索引--以后安装更快捷7.安装Docker-Ce8.启动Docker9.测试10.卸载1…...

「实用分享」如何用Telerik UI组件创建可扩展的企业级WPF应用?

Telerik UI for WPF拥有超过100个控件来创建美观、高性能的桌面应用程序&#xff0c;同时还能快速构建企业级办公WPF应用程序。UI for WPF支持MVVM、触摸等&#xff0c;创建的应用程序可靠且结构良好&#xff0c;非常容易维护&#xff0c;其直观的API将无缝地集成Visual Studio…...

【Docker基础三】Docker安装Redis

下载镜像 根据自己需要下载指定版本镜像&#xff0c;所有版本看这&#xff1a;Index of /releases/ (redis.io) 或 https://hub.docker.com/_/redis # 下载指定版本redis镜像 docker pull redis:7.2.0 # 查看镜像是否下载成功 docker images 创建挂载目录 # 宿主机上创建挂…...

沈阳自助建站软件/西安高端网站建设公司

题意&#xff0c;四个柱子的汉诺塔 来自&#xff1a;http://blog.csdn.net/pmt123456/article/details/53571989 一、经典汉诺塔 有三根相邻的柱子&#xff0c;标号为A,B,C&#xff0c;A柱子上从下到上按金字塔状叠放着n个不同大小的圆盘&#xff0c;要把所有盘子一个一个移动到…...

如何查看网站是哪家公司做的/培训学校怎么招生

我已经到了秃顶几步之遥…我正在尝试运行一项服务&#xff0c;该服务将检查我工作中的服务器是否正在运行。应该每5分钟执行一次。我经历过TimerTask&#xff0c;ScheduledExecutorService&#xff0c;最后是Handler。他们都工作了好几个小时&#xff0c;除了一些不准确的地方外…...

什么网站做装修的/链接买卖

前言 在微服务实战&#xff1a;基于Spring Cloud Gateway AWS Cognito 的BFF案例一文中&#xff0c; 介绍了基于Amazon Cognito的OAuth授权码模式的认证流程。本文中&#xff0c;我们将研究可能针对此流程的恶意攻击以及如何防止它们。你将了解如何使用状态随机数&#xff08…...

做网站需要学会什么/新闻 近期大事件

为什么机器人能看到你&#xff1f; 因为它有自己的眼睛。机器视觉检测作为人工智能技术的一种。 可以通过利用计算机模拟人的视觉功能&#xff0c;从画面中提取关键信息&#xff0c;对其进行处理&#xff0c;最终用于实际的检测&#xff0c;测量和控制。 技能的最大特点是速度快…...

清城区做模板网站建设/网站建设找哪家公司好

《Java程序设计》试卷三一、选择题(2分*2550分)&#xff11;、下列关于栈的叙述正确的是A) 栈是非线性结构B) 栈是一种树状结构C) 栈具有先进先出的特征D) 栈具有后进先出的特征&#xff12;、下列不是InputStream子类的是A) 文件输入流FileInputStreamB) 对象输入流ObjectInpu…...

公司注册代办公司靠谱吗/廊坊百度快照优化排名

操作步骤&#xff1a; 新建/opt/install目录&#xff08;随便建&#xff0c;脚本中路径一致就行&#xff09;将installjdk&#xff08;安装命令脚本&#xff09;,java&#xff08;环境变量配置脚本&#xff09;,jdk-8u201-linux-x64.tar.gz&#xff08;安装包也可是其他版本JD…...