Python 挖坑式填充Excel模板内容(包括页眉/SheetName/logo)

纵览

  • Python处理Excel的方式--解压缩方式
      • 1、导包
      • 2、对模板文件进行解压缩
      • 3、对解压缩后文件层级进行介绍
      • 4、准备需要载入的数据
      • 5、模板挖坑
      • 6、运行替换代码
      • 7、压缩文件
      • 8、生成文件
      • 9、完成代码
      • 10、可能遇到的问题
  • 结语

Python处理Excel的方式–解压缩方式

在处理Excel中过程中,总是会遇到往已经存在的模板中填写特殊信息,一开始我使用的是常见的 openpyxl包,但是在我修改页眉中的字符时,发生页眉中的logo丢失现象,然后我就百度、ChatGPT搜索,最终找到了一种方法,那就是解压缩xlsx文件,然后修改内容,再进行压缩的方式实现修改内容的功能,利用的zipfile包,当然这个包应该是自带的吧,我使用的是Anaconda

1、导包

其中部分包没有用到

import zipfile
import os
import shutil
from openpyxl import load_workbook
import pandas as pd

2、对模板文件进行解压缩

# 模板Excel文件路径
excel_path = r'D:\MyPython\程序\模版.xlsx'
# 解压缩 Excel 文件
with zipfile.ZipFile(excel_path, 'r') as zip_ref:zip_ref.extractall('excel_temp')

3、对解压缩后文件层级进行介绍

运行上述代码,会在当前目录下,生成一个文件夹excel_temp,目录结构如下:
在这里插入图片描述
其中,主要关注的是xl文件夹里面的文件,文件内容意思如下:

路径文件名功能
excel_temp/xl/sharedStrings.xmlExcel中的所有单元格内容,除页脚、页眉外,所有的信息都在这里
excel_temp/xl/workbook.xmlsheetname修改位置
excel_temp/xl/worksheets/styles.xml修改单元格的样式
excel_temp/xl/worksheets/sheet?.xml页眉页脚修改区域修改位置,每个sheet对应1个文件
excel_temp/xl/drawings/_rels/drawing1.xml.rels页眉页脚修改区域修改位置,每个sheet对应1个文件图片路径的,如果模板中已经存在图片的,如果想要换个图标,可以通过覆盖下面的图片就行
excel_temp/xl/media/image?.png将新的文件覆盖掉对应的png文件就行,可以利用shutil.copy(替换图片路径,要被替换的路径)

4、准备需要载入的数据

替换模板数据,最重要的是先将你要替换的数据整理好,然后再在模板中相应的位置挖空,填充就行,我的数据格式是excel,如下:A列是替换名称,B到D列是数据,然后运行代码会生成填入B、C、D对应的数据的三个文件;
在这里插入图片描述

5、模板挖坑

打开模板文件,将需要替换的位置成相应的字符,比如:现在我想要替换发光点数量,输入发光点数量替换值,这个可以根据自己实际情况更换;
在这里插入图片描述

6、运行替换代码

excel_path是模板路径,soure_file数据文件;

data_df = pd.read_excel(soure_file,sheet_name=0) #,usecols=[0,1]
# 将某一列(例如'index_column')设为索引
data_df.set_index('字段', inplace=True)
# 将DataFrame转换为字典
data_dict = data_df.to_dict()# 删除值为NaN的键值对
data1_dict = {col: {index: value for index, value in data_dict[col].items() if pd.notna(value)} for col in data_dict}
# 修改页眉 文件
for keya in data1_dict.keys():# 解压缩 Excel 文件with zipfile.ZipFile(excel_path, 'r') as zip_ref:zip_ref.extractall('excel_temp')# 修改相关 XML 文件content_path = 'excel_temp/xl/sharedStrings.xml'workbook_path = 'excel_temp/xl/workbook.xml'for fm in os.listdir('excel_temp/xl/worksheets'):if '.xml' in fm:with open(f'excel_temp/xl/worksheets/{fm}', 'r+') as f:header_footer_xml = f.read()for key,value in data1_dict[keya].items():header_footer_xml = header_footer_xml.replace(key+'替换值', str(value))f.seek(0)f.write(header_footer_xml)f.truncate()# 修改内容 文件with open(content_path, 'r+') as f:header_footer_xml = f.read()for key,value in data1_dict[keya].items():header_footer_xml = header_footer_xml.replace(key+'替换值', str(value))f.seek(0)f.write(header_footer_xml)f.truncate()# 修改类似:sheetname 这样的字符# 修改Sheetname文件with open(workbook_path, 'r+') as f:header_footer_xml = f.read()header_footer_xml = header_footer_xml.replace("SHEETNAME", data1_dict[keya]['SheetName'].replace('/',''))f.seek(0)f.write(header_footer_xml)f.truncate()

7、压缩文件

将修改后的文件,重新压缩,并且删除临时文件夹excel_temp

# 重新压缩 Excel 文件
with zipfile.ZipFile(data1_dict[keya]['Name'].replace('/','')+'.xlsx', 'w') as zip_ref:for folder_name, subfolders, filenames in os.walk('excel_temp'):for filename in filenames:file_path = os.path.join(folder_name, filename)arcname = os.path.relpath(file_path, 'excel_temp')zip_ref.write(file_path, arcname)
# 删除临时文件夹
shutil.rmtree('excel_temp')

8、生成文件

运行完成后,会在当前目录下生成对应的文件,如果你想要放在其他路径可以修改data1_dict[keya]['Name'].replace('/','')+'.xlsx'这个位置的代码,利用os.path.join()进行路径拼接即可。

9、完成代码

文件存在关键信息,我就不展示了,代码如下:

import zipfile
import os
import shutil
from openpyxl import load_workbook
import pandas as pd
# 修改页眉 文件
def get_file(excel_path, soure_file):data_df = pd.read_excel(soure_file,sheet_name=0) #,usecols=[0,1]# 将某一列(例如'index_column')设为索引data_df.set_index('序列', inplace=True)# 将DataFrame转换为字典data_dict = data_df.to_dict()# 删除值为NaN的键值对data1_dict = {col: {index: value for index, value in data_dict[col].items() if pd.notna(value)} for col in data_dict}for keya in data1_dict.keys():# 解压缩 Excel 文件with zipfile.ZipFile(excel_path, 'r') as zip_ref:zip_ref.extractall('excel_temp')# 修改相关 XML 文件content_path = 'excel_temp/xl/sharedStrings.xml'workbook_path = 'excel_temp/xl/workbook.xml'for fm in os.listdir('excel_temp/xl/worksheets'):if '.xml' in fm:with open(f'excel_temp/xl/worksheets/{fm}', 'r+') as f:header_footer_xml = f.read()for key,value in data1_dict[keya].items():header_footer_xml = header_footer_xml.replace(key+'替换值', str(value))f.seek(0)f.write(header_footer_xml)f.truncate()# 修改内容 文件with open(content_path, 'r+') as f:header_footer_xml = f.read()for key,value in data1_dict[keya].items():header_footer_xml = header_footer_xml.replace(key+'替换值', str(value))f.seek(0)f.write(header_footer_xml)f.truncate()# 修改类似:这样的字符# 修改Sheetname文件with open(workbook_path, 'r+') as f:header_footer_xml = f.read()header_footer_xml = header_footer_xml.replace("SHEETNAME", data1_dict[keya]['SheetName'].replace('/',''))f.seek(0)f.write(header_footer_xml)f.truncate()# 重新压缩 Excel 文件with zipfile.ZipFile(data1_dict[keya]['产品类别'].replace('/','')+'.xlsx', 'w') as zip_ref:for folder_name, subfolders, filenames in os.walk('excel_temp'):for filename in filenames:file_path = os.path.join(folder_name, filename)arcname = os.path.relpath(file_path, 'excel_temp')zip_ref.write(file_path, arcname)# 删除临时文件夹shutil.rmtree('excel_temp')
excel_path = r'D:\MyPython\程序\Nan_Czy\流程单自动生成\模版.xlsx'
soure_file = r'D:\MyPython\程序\Nan_Czy\流程单自动生成\关键信息清单.xlsx'
get_file(excel_path, soure_file)

10、可能遇到的问题

  • 读取文件存在问题,需要在对应位置加上:encoding='utf-8'
  • 打开文件失败,肯定是替换的字符存在问题,需要一一排查;

结语

好的,本次遇到的问题已经解决并且记录下来了,希望能够帮助你!

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

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

相关文章

《人人都是产品经理》:项目的坎坷一生

《人人都是产品经理》:项目的坎坷一生 产品VS项目产品经理和项目经理 一切项目从kick off 开始工作量预估Kick Off的大致也就15分钟 写文档咯UML图用例文档UCdemo也得做 需求活在项目中bug等级有多高bug流转过程 以终为始 产品VS项目 项目定义:是只会进…

navict sql 复制出来 带逗号分隔的,如:(1, 2, 3, 4, 5)

1. 假如我们要查询一个表中所有的id, 拼接成括号逗号分隔形式 select id from student1 2 3 4 5 2. 解决办法:使用函数创建一个对应的函数 如下是sql代码: # 删除函数 drop FUNCTION if EXISTS sm; # 创建函数 CREATE FUNCTION sm(s TEXT) RETURNS …

怎么压缩pdf文件大小,如何压缩pdf文件大小

pdf文件怎么压缩?在当下这个信息爆炸的时代,无论是在工作场所还是校园中,我们经常会面临需要处理大文件的情况,而PDF格式作为一种保留文档结构和布局完整性的理想选择,有时候pdf文件太大,因此,对…

【vdbench性能测试】Slaver连Master显示连接超时,大概率etc/hosts文件出问题

报错类似: slavejvm execution parameter: -m 127.0.1.1 slavejvm execution parameter: -n xx.xx.xx.xx-11-240626-15.21.50.164 slavejvm execution parameter: -l hd2-0 15:21:50.833 15:21:50.832 slavejvm execution parameter: -p 5570 slavejvm positio…

typec密封胶防水用什么胶好?

typec密封胶防水用什么胶好? 对于Type-C连接器的防水密封,行业内普遍推荐使用单组份环氧型热固化胶。这种胶水具有以下优点,使其成为Type-C防水密封的理想选择: 粘稠度易于调整:这有助于胶水在点胶过程中更好地渗透到T…

基于深度学习的点云包围盒检测

基于深度学习的点云包围盒检测 点云包围盒检测是一项关键任务,主要用于三维场景中物体的检测和定位。与传统的二维图像目标检测不同,点云数据包含了三维空间的信息,能够提供更加丰富的细节和准确的位置。基于深度学习的方法在点云包围盒检测…

2024年二级建造师机电工程专业考试题库分享。

1.调查表法通常与()结合使用,以便更快地发现问题原因。 A.经验法 B.分层法 C.样本调查法 D.对比分析法 答案:B 解析:题干内容提示调查表法往往会与分层法结合起来应用,故B选项正确。 2.在质量统计分…

nestjs从零到一,快速上手(七) 拦截器的使用

演示代码: 1. logs.controller.ts import { Body, Controller, Post, UseInterceptors } from nestjs/common; import { IsNotEmpty, IsString } from class-validator; import { SerializeInterceptor } from ../interceptors/serialize/serialize.interceptor; …

压缩图片png格式该怎么操作?试试下面这3个图片压缩工具吧

png是经常用于储存图片的一种格式,随着现在图片在日常工作和生活中的广泛使用,在很多的使用场景中都有应用。png的图片质量高而且支持无损压缩,在缩小图片的时候不会因为压缩而影响图片的清晰度,更适合在网上的存储、分享或者传输…

论文阅读MVBench: A Comprehensive Multi-modal Video Understanding Benchmark

摘要(Abstract): 论文介绍了MVBench,这是一个全新的多模态视频理解基准测试,旨在评估多模态大型语言模型(MLLMs)在视频理解方面的能力。 目前许多基准测试主要集中在静态图像任务的空间理解上,而忽视了动…

c++进程间通信--zeromq

ZeroMQ(也写作 MQ、0MQ 或 zmq)是一个高性能的异步消息队列库,提供了一种灵活的方式来实现进程间通信(IPC)以及网络通信。在C中使用ZeroMQ进行进程间通信非常直观和高效。zmq的通信模式如下: 下面先说明请求…

保护你的代码堡垒:精通npm audit命令

保护你的代码堡垒:精通npm audit命令 在当今快速发展的软件开发领域,安全漏洞如同暗夜中的刺客,随时可能对我们的应用程序发起致命一击。幸运的是,npm提供了一个强大的安全审计工具——npm audit命令,它能帮我们检测和…

第 11 课:组件介绍与自定义开发

本讲主要介绍了隐语的组件标准、已有的组件能力以及进一步的自定义开发流程。经过本讲的学习,可以为将隐语集成到任意调度系统,基于Kusica/SecretPad进行二次开发,以及参与隐语开放标准共建建立基础。 一、隐语开放标准 隐语提出的适用于隐私…

2024.06.26【读书笔记】|医疗科技创新流程(前言)【AI增强版】

目录 《BIODESIGN》第二版前言详细总结前言概述新增重要内容价值导向 (Value Orientation)全球视角 (Global Perspectives)更好的教学和学习方法 (Better Ways to Teach and Learn)全新视频集合 (New Videos)扩展的“实地”案例研究 (Expanded “From the Field” Case Studies…

产品3D展示有哪些优势?3D能替代2D展示吗?

随着科技的飞速发展和经济的持续增长,我们见证了一个从2D到3D的产品展示革命。与传统的2D图片展示相比,3D产品展示正以其独特的优势逐渐崭露头角。 一、3D产品展示的独特优势 1、更逼真的视觉效果: 3D展示技术能够以更为真实、立体的方式展…

证件照制作工具有哪些?这6个帮你自制证件照

许多人可能认为,制作一张符合标准要求的证件照,必须亲自前往照相馆。 然而,事实上,我们完全可以使用手机或电脑上的证件照制作app,自己轻松完成证件照的制作。无论是更换背景颜色,还是调整照片尺寸&#x…

qt qml-http之XMLHttpRequest介绍详解使用

文章目录 QML中的XMLHttpRequest详解与示例基本用法示例代码代码详解更复杂的示例:POST请求代码详解结论QML中的XMLHttpRequest详解与示例 XMLHttpRequest 是 QML 中用于执行HTTP请求的一种机制,类似于Web中的AJAX。它可以用来进行异步的数据传输,可以从服务器获取数据,也…

【ARM】Ulink不同的系列对于芯片的支持和可以支持keil软件

【更多软件使用问题请点击亿道电子官方网站】 1、 文档目标 了解不同版本的ULINK可以支持的芯片架构,和ULINK可以和哪个系列的keil软件进行在线调试 2、 问题场景 用于了解不同ULINK仿真器对于芯片的支持是不一样的,并不是ULINK可以支持所有的keil软件…

typescript 枚举类型

枚举类型 枚举类型是为数不多的特有类型之一,它允许开发者定义一组命名常量,这些常量可以是数字或字符串类型。枚举类型提供了一种方式来组织和管理一组相关的值,使得代码更加清晰和易于理解。 数字枚举类型 enum Direction1 {Up 1, //初…

1. ansible作用、部署

ansible作用、部署 一、ansible介绍1、ansible特性 二、ansible安装部署1、建议配置ssh免密2、安装ansible3、配置主机清单文件 /etc/ansible/hosts3.1 未分组的写法3.2 分组的写法 4、添加非免密的主机 一、ansible介绍 基于python语言开发的,自动化运维工具 作用…