如何保留 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. 解决办法 经思考,此问题可抽象为:在不影响原始数据的 ...
随机推荐
- kubelet 原理分析
Reference https://atbug.com/kubelet-source-code-analysis/ kubelet 简介 kubernetes 分为控制面和数据面,kubelet 就是 ...
- 2024-04-21:用go语言,给一棵根为1的树,每次询问子树颜色种类数。 假设节点总数为n,颜色总数为m, 每个节点的颜色,依次给出,整棵树以1节点做头, 有k次查询,询问某个节点为头的子树,一共
2024-04-21:用go语言,给一棵根为1的树,每次询问子树颜色种类数. 假设节点总数为n,颜色总数为m, 每个节点的颜色,依次给出,整棵树以1节点做头, 有k次查询,询问某个节点为头的子树,一共 ...
- [Go] go build 和 go install 的区别
$ go build 源文件及其包依赖 编译成二进制. install 不仅执行build过程 而且会把编译的二进制放到 $GOPATH/bin/,包放到 $GOPATH/pkg/ Link:http ...
- [Py] Failed to import pydot. You must install pydot and graphviz for `pydotprint` to work
当通过常规命令安装 pip install pydot 和 brew install graphviz 之后,在代码中 import pydot 依旧不生效. 比如:在 tensorflow 使用 t ...
- dotnet 使用 ConfigureAwait.Fody 库设置默认的 await 同步上下文切换配置
在 dotnet 里面,使用 await 进行异步逻辑,默认是会尝试切换回调用 await 的线程同步上下文.这个机制对于大多数的上层应用来说都是符合逻辑且方便的逻辑,例如对于带 UI 线程的 WPF ...
- 特权同学笔记-《边练边学》-在QP里调用modelsim的步骤
在QP里调用Modelsim需要先设置仿真参数和工具路径. 在QP调用modelsim的步骤 1. 在QP里建立工程,代码,分析综合:2. 添加testbench代码,processing-start ...
- MacOS M1芯片openmp库出现mach-o file, but is an incompatible architecture (have ‘arm64‘, need ‘x86_64‘问题解决
目录 1. 问题描述 2. 问题出现原因 3. 解决方案 编译安装 使用Homebrew安装 Reference 1. 问题描述 报错如下所示: ImportError: dlopen(/Users/ ...
- 03 Xpath lxml库的安装和使用
Python lxml库的安装和使用 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 Xpath 表达式提供了良好的支持,因此能够了高效地解析 HTML/XML 文 ...
- 解决VMware Workstation 与 Device/Credential Guard不兼容
参考文档 https://blog.csdn.net/lizhengze1117/article/details/106566060
- ansible(15)--ansible的mount模块
1. mount模块 功能:管理被控端设备挂载: 主要参数如下: 参数 说明 src 本地或远程设备的路径 path 设备挂载至本地的路径 fstype 挂载的文件系统类型,xfs.nfs... op ...