如何保留 Excel 表头和第一行数据并追加 CSV 数据
准备工作
在开始之前,确保你的 Python 环境中已经安装了 openpyxl 和 pandas 库。可以使用以下命令进行安装:
pip install openpyxl pandas
第一步:编写函数保留表头和第一行数据
我们首先编写一个函数 keep_first_two_rows,用于保留指定工作表的表头和第一行数据,其余数据将被删除。
from openpyxl import load_workbook def keep_first_two_rows(filepath, sheetname):
try:
# 加载 Excel 文件
wb = load_workbook(filepath)
ws = wb[sheetname] # 删除第三行之后的所有行
ws.delete_rows(3, ws.max_row) # 保存修改后的 Excel 文件
wb.save(filepath)
print(f"成功保留表头和第一行数据到工作表 {sheetname}")
except Exception as e:
print(f"保留表头和第一行数据时出错: {e}")
解释:
load_workbook(filepath):加载指定路径的 Excel 文件。wb[sheetname]:获取指定名称的工作表。ws.delete_rows(3, ws.max_row):从第三行开始删除所有后续行,只保留前两行。wb.save(filepath):保存对 Excel 文件的修改。
第二步:编写函数追加 CSV 数据
接下来,我们编写一个函数 append_data_from_csv,用于将 CSV 文件中的数据追加到指定工作表的末尾。
import pandas as pd
from openpyxl import load_workbook def append_data_from_csv(filepath, sheetname, csv_filepath):
try:
# 从 CSV 文件中读取新数据
new_data = pd.read_csv(csv_filepath) # 加载 Excel 文件
wb = load_workbook(filepath)
ws = wb[sheetname] # 将新数据追加到工作表末尾
for r_idx, row in enumerate(new_data.values, ws.max_row + 1):
for c_idx, value in enumerate(row, 1):
ws.cell(row=r_idx, column=c_idx, value=value) # 保存修改后的 Excel 文件
wb.save(filepath)
print(f"成功从 CSV 文件中追加新数据到工作表 {sheetname} 后面")
except Exception as e:
print(f"追加新数据时出错: {e}")
解释:
pd.read_csv(csv_filepath):使用 pandas 从指定路径读取 CSV 文件中的数据。wb[sheetname]:获取指定名称的工作表。enumerate(new_data.values, ws.max_row + 1):从工作表的最后一行开始,逐行追加 CSV 数据。ws.cell(row=r_idx, column=c_idx, value=value):将 CSV 文件中的每个值插入到 Excel 工作表的对应单元格中。wb.save(filepath):保存对 Excel 文件的修改。
第三步:主程序调用
最后,我们编写主程序,调用以上两个函数,完成具体操作。
if __name__ == "__main__":
# 指定 Excel 文件路径、工作表名和 CSV 文件路径
excel_file_path = "C:\\Users\\Administrator\\Desktop\\销售系数数据同步.xlsx"
sheet_name = "商品费用"
csv_file_path = "F:\\工作内容\\我的数据\\商品费用解析数据\\商品费用数据汇总.csv" # 调用函数保留表头和第一行数据
keep_first_two_rows(excel_file_path, sheet_name) # 调用函数从 CSV 文件中追加新数据到指定工作表后面
append_data_from_csv(excel_file_path, sheet_name, csv_file_path)
解释:
excel_file_path:指定 Excel 文件的路径。sheet_name:指定工作表名称。csv_file_path:指定 CSV 文件的路径。keep_first_two_rows(excel_file_path, sheet_name):调用函数保留表头和第一行数据。append_data_from_csv(excel_file_path, sheet_name, csv_file_path):调用函数从 CSV 文件中追加新数据到指定工作表。
完整代码
from openpyxl import load_workbook
import pandas as pd def keep_first_two_rows(filepath, sheetname):
try:
# 加载 Excel 文件
wb = load_workbook(filepath)
ws = wb[sheetname] # 删除第三行之后的所有行
ws.delete_rows(3, ws.max_row) # 保存修改后的 Excel 文件
wb.save(filepath)
print(f"成功保留表头和第一行数据到工作表 {sheetname}")
except Exception as e:
print(f"保留表头和第一行数据时出错: {e}") def append_data_from_csv(filepath, sheetname, csv_filepath):
try:
# 从 CSV 文件中读取新数据
new_data = pd.read_csv(csv_filepath) # 加载 Excel 文件
wb = load_workbook(filepath)
ws = wb[sheetname] # 将新数据追加到工作表末尾
for r_idx, row in enumerate(new_data.values, ws.max_row + 1):
for c_idx, value in enumerate(row, 1):
ws.cell(row=r_idx, column=c_idx, value=value) # 保存修改后的 Excel 文件
wb.save(filepath)
print(f"成功从 CSV 文件中追加新数据到工作表 {sheetname} 后面")
except Exception as e:
print(f"追加新数据时出错: {e}") if __name__ == "__main__":
# 指定 Excel 文件路径、工作表名和 CSV 文件路径
excel_file_path = "C:\\Users\\Administrator\\Desktop\\销售系数数据同步.xlsx"
sheet_name = "商品费用"
csv_file_path = "F:\\工作内容\\我的数据\\商品费用解析数据\\商品费用数据汇总.csv" # 调用函数保留表头和第一行数据
keep_first_two_rows(excel_file_path, sheet_name) # 调用函数从 CSV 文件中追加新数据到指定工作表后面
append_data_from_csv(excel_file_path, sheet_name, csv_file_path)
如何保留 Excel 表头和第一行数据并追加 CSV 数据的更多相关文章
- Python:读取Excel 不带第一行标题
#根据第0到第1列进行重建 0-X 1-Y PX=sheet_name.col_values(0)[1:] PY=sheet_name.col_values(1)[1:] 读取的某一列后在后边加[1: ...
- python openpyxl模块实现excel的读取,新表创建及原数据表追加新数据
当实际工作需要把excel表的数据读取出来,或者把一些统计数据写入excel表中时,一个设计丰富,文档便于寻找的模块就会显得特别的有吸引力,本文对openpyxl模块的一些常见用法做一些记录,方便工作 ...
- Jmeter系列(32)- 详解 CSV 数据文件设置
如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 了解一哈什么是 CSV 文件 为了实现 ...
- Pandas_数据读取与存储数据(全面但不精炼)
Pandas 读取和存储数据 目录 读取 csv数据 读取 txt数据 存储 csv 和 txt 文件 读取和存储 json数据 读取和存储 excel数据 一道练习题 参考 Numpy基础(全) P ...
- form表单序列化数据之后,追加额外数据
form表单序列化数据之后追加额外数据多使用在js中,下面是追加额外数据的代码: <span style="font-size:18px;">$.param({'inv ...
- python 去除Excel中的重复行数据
导入pandas import pandas as pd 1.读取excel中的数据: frame = pd.DataFrame(pd.read_csv('excel的绝对路径.csv'', 'She ...
- 一个将当前目录下HEX文件的第一行数据删除的程序
为什么要写这样一个函数 在使用SoftConsole开发M3程序时,生成的hex文件,必须要把第一行数据删除,才能在Libero中使用,所以写了这个小工具,这是2.0版本了,第一版是直接删除第一行数据 ...
- 四十四、在SAP中冻结第一行表头
一.表格数据量大了,如果需要界面滚动,则看不到第一行的表头文本 二.代码如下: 二.效果如下,任意滚动,表头还是被冻结可以看到
- (转)supertable像excel那样固定table的表头和第一列
<!DOCTYPE HTML> <html> <head> <meta charset="utf-8"/> <title> ...
- pandas:字段值插入数据表第一行的解决办法
1. 问题描述 在对课程表进行数据抽取时,由于课表结构的原因,需要在原始表字段名作为第一行数据,并对原始字段名进行替换. 原始数据如下所示: 2. 解决办法 经思考,此问题可抽象为:在不影响原始数据的 ...
随机推荐
- drf——基于apiview写过滤、排序和分页
基于APIView带过滤和排序 from rest_framework.views import APIView from .models import Book from .serializer i ...
- Dataphin产品核心功能大图(六)发布中心:生产和开发隔离模式下的保护伞
简介:Dataphin,用中台方法论打造企业级好数据.Dataphin是阿里巴巴集团OneData数据治理方法论内部实践的云化输出,一站式提供数据采.建.管.用全生命周期的大数据能力,以助力企业显著 ...
- 贝壳基于 Flink 的实时计算演进之路
简介: 贝壳找房在实时计算之路上的平台建设以及实时数仓应用. 摘要:贝壳找房大数据平台实时计算负责人刘力云带来的分享内容是贝壳找房的实时计算演进之路,内容如下: 发展历程 平台建设 实时数仓及其应用场 ...
- 如何保证 Serverless 业务部署更新的一致性?
简介: 代码在其他场景被更新,需要我们在当前得到感知,这个事情其实是非常重要的,和代码的安全发布密不可少.而此时,通过 Serverless Devs 是可以做到的. 作者|Anycodes 从我做 ...
- 漫画 | 一口气搞懂 Serverless !
简介: 第二届云原生编程挑战赛为热爱技术的年轻人提供一个挑战世界级技术问题的舞台,希望用技术为全社会创造更大价值. 作者 | 刘欣 呃,我可能是别人眼中所说的不用奋斗的一代. 大家喜欢听的什么多姿多 ...
- 读书笔记 dotnet 的字符串在内存是如何存放
本文是读伟民哥翻译的 .NET内存管理宝典 这本书的笔记,我认为读书的过程也需要实践,这样对一知半解的知识也有较为清晰的了解.在阅读到 string 在内存的布局时,我看到 RuntimeHelper ...
- LLM应用实战:当KBQA集成LLM(二)
1. 背景 又两周过去了,本qiang~依然奋斗在上周提到的项目KBQA集成LLM,感兴趣的可通过传送门查阅先前的文章<LLM应用实战:当KBQA集成LLM>. 本次又有什么更新呢?主要是 ...
- Soluton Set - ZJOI历年真题
upd:不考浙江省选了.这个题解贴应该不会再更新了. upd:进省队了.再做点,再写点. ZJOI2022 Day1T1 Link&Submission. tag:组合计数,容斥 假设固定了第 ...
- InternLM2 Demo实操-书生浦语大模型实战营第二期第2节作业&大语言模型3
大语言模型-3.InternLM2 Demo实操 书生浦语大模型实战营第二期第二节作业 本文包括第二期实战营的第2课作业的相关内容.本来是想在学习笔记中给InetrnLM官方教程做做补充的,没想到官方 ...
- CMS垃圾收集器小实验之CMSInitiatingOccupancyFraction参数
CMS垃圾收集器小实验之CMSInitiatingOccupancyFraction参数 背景 测试CMSInitiatingOccupancyFraction参数,测试结果和我的预期不符,所以花了一 ...