【办公类-19-02】20240122图书EXCEL插入列并删除空行

2024-01-23 14:12

本文主要是介绍【办公类-19-02】20240122图书EXCEL插入列并删除空行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作品展示

背景需求

上次23个班级班主任统计图书,写在EXCEL内

【办公类-19-01】20240108图书统计登记表制作(23个班级)EXCEL复制表格并合并表格-CSDN博客文章浏览阅读693次,点赞12次,收藏7次。【办公类-19-01】20240108图书统计登记表制作(23个班级)EXCEL复制表格并合并表格https://blog.csdn.net/reasonsummer/article/details/135473511提交后

每个班级的图书数量不一致,

需求

1、删除多余的空行

2、在序号和书名中间加入“年级”“班级”

素材准备:

全部代码

'''
把每个EXCEL前面增加一列班级、一列年级。共生成25份
删除多余行
作者:阿夏
时间:2024年1月22日'''
from openpyxl import Workbook
from openpyxl.styles import Alignment
from openpyxl.styles import Border, Side
import openpyxl
from docx import Document
import os
from docx.enum.text import WD_BREAK# 换页符号
from docx.enum.section import WD_SECTION
from docx.shared import Pt,Inches, Cm
#导入模块xlrd
import xlrd
import openpyxl
# import pandas as pd
import os
import time
import win32com.client as win32imagePath=r'C:\Users\jg2yXRZ\OneDrive\桌面\图书'print('------------第1步:读取原始文件-------------')# 新建一个”装N份word和PDF“的临时文件夹
imagePath1=imagePath+r'\\02插入班级年级的班级图书'
if not os.path.exists(imagePath1):  # 判断存放图片的文件夹是否存在os.makedirs(imagePath1)  # 若图片文件夹不存在就创建# 指定要读取的文件夹路径
folder_path = r'C:\Users\jg2yXRZ\OneDrive\桌面\图书\01班主任提交的图书'
# 获取文件夹内所有文件名
file_names = os.listdir(folder_path)
# 拼接文件路径
doc_paths = [os.path.join(folder_path, file_name) for file_name in file_names]
print(doc_paths)
# ['C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大1班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大2班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大3班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大4班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大5班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大6班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\大7班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\小1班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\小2班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\小3班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌 
# 面\\图书\\所有图书\\小4班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\小5班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图 
# 书\\所有图书\\小6班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\小7班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所 
# 有图书\\托1班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\托2班班级图书汇总表.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\测试.xlsx', 'C:\\Users\\jg2yXRZ\\OneDrive\\桌面\\图书\\所有图书\\测试2.xlsx']print('------------第2步:每个EXCEL插入两列班级年级-------------')
# 遍历所有的EXCLE,添加班级列和年级列
for x  in range(len(doc_paths)):# 读取Excel文件workbook = openpyxl.load_workbook(r'{}'.format(doc_paths[x]))# 获取第一个工作表worksheet = workbook.worksheets[0]# 插入两列grade=['班级','年级']title=[]# 提取标题=班级cells=worksheet['A1']# 大1title1=cells.value[6:8]# 大班组title2=cells.value[6:7]+'班组'title.append(title1)title.append(title2)print(title)# 写入两列 班级和年级for i in range(len(grade)):# 在A列后插入一列B,并填写为"小1班"worksheet.insert_cols(2)# 在第2列前插入一列worksheet['B2']=grade[i]# 先插入班级,再插年级# 插入列的宽度worksheet.column_dimensions['B'].width = 10worksheet.column_dimensions['C'].width = 10# 获取行数row_count = worksheet.max_row    # 填写B列的单元格为"小1班"for row in range(3, row_count + 1):alignment = Alignment(horizontal='center')   worksheet.cell(row=row, column=2,value=title[i]).alignment = alignment# 获取活动工作表ws1 = workbook.active# 添加表格框线   假设你要设置的数据范围是第2行到第总行数+1行,第2列到第3列=第2列for col in ws1.iter_cols(min_row=3, max_row=row_count + 1, min_col=2, max_col=5):  # 注意:max_row应该是11,因为你要包括第10行for cell in col:cell.border = Border(left=Side(style='thin'),right=Side(style='thin'),top=Side(style='thin'),bottom=Side(style='thin'))# E列出版社和F列ISBN列宽变长         worksheet.column_dimensions['E'].width = 20worksheet.column_dimensions['F'].width = 20# 标签名字改成大1   ,不改就是“Sheet1”worksheet.title=title[0]# 删除“书名、出版社、ISDN”号三列都是空的行数,需要循环删除   # worksheet = workbook.activefor row in  worksheet.iter_rows(min_row=3, max_row= worksheet.max_row, min_col=4, max_col=6):    # 4=D# 因为删除一个空行后,行数上移,可能会跳过某些空行,所以最多循环350次,反复删除空行for y in range(365):            # 生成时间长# 检查D、E和F列的单元格是否都为空if all(cell.value is None for cell in row):# 如果都为空,删除整行worksheet.delete_rows(row[0].row)# 保存修改后的Excel文件workbook.save(imagePath+r'\\02插入班级年级的班级图书\新{}'.format(doc_paths[x][-15:]))workbook.close()print('------------第4步:将改过的新图书放在一张表里,保留原始格式-------------')# # 把整理里面的多个EXCEL工作表合并在一个工作表内N个工作簿、# print('---第3步:把23个工作簿合并1个工作簿的N个工作表-----')# a=r'C:\Users\jg2yXRZ\OneDrive\桌面\图书\各班填写后EXCEL.xlsx'
# print(a)# def merge_excel_files(path):
#     # create a new Excel workbook or open an existing one
#     excel = win32.gencache.EnsureDispatch('Excel.Application')
#     try:
#         wb = excel.Workbooks.Open(os.path.join(path, a))
#     except:
#         wb = excel.Workbooks.Add()#     # loop through all Excel files in the folder
#     for file in os.listdir(path):
#         print(file)
#         # 大5班班级图书汇总表.xlsx
#         if file.endswith('.xlsx'):            # open the Excel file打开EXCEL文件
#             ww=path+'\\'+file
#             print(ww)
#             wb_source = excel.Workbooks.Open(os.path.join(path, file))
#             print(wb_source)
#             # loop through all worksheets in the Excel file 所有文件内容
#             for sheet in wb_source.Worksheets:#                 # copy the worksheet to the destination workbook 复制表格内容到目标文件内,将其放到N工作表格后面
#                 sheet.Copy(After=wb.Sheets(wb.Sheets.Count))#             # close the source workbook 关闭来源文件
#             wb_source.Close()#     # save and close the destination workbook
#     wb.SaveAs(os.path.join(path, a))
#     wb.Close()
#     excel.Quit()#     # delete Sheet1 from 合并.xlsx
#     excel = win32.gencache.EnsureDispatch('Excel.Application')
#     wb = excel.Workbooks.Open(os.path.join(path, a))
#     ws = wb.Worksheets('Sheet1')
#     ws.Delete()
#     wb.Save()
#     wb.Close()
#     excel.Quit()# path = imagePath+r'\\02插入班级年级的班级图书'
# merge_excel_files(path)

终端演示:

最终成果

还没有研究出来如何将这么多工作表,合并在一张工作表的一个工作簿里,并保留原来的格式。

待续

这篇关于【办公类-19-02】20240122图书EXCEL插入列并删除空行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/636626

相关文章

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

如何在Mac上彻底删除Edge账户? 手动卸载Edge浏览器并清理残留文件技巧

《如何在Mac上彻底删除Edge账户?手动卸载Edge浏览器并清理残留文件技巧》Mac上的Edge账户里存了不少网站密码和个人信息,结果同事一不小心打开了,简直尴尬到爆炸,想要卸载edge浏览器并清... 如果你遇到 Microsoft Edge 浏览器运行迟缓、频繁崩溃或网页加载异常等问题,可以尝试多种方

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir