当前位置: 首页
编程语言
Python如何覆盖与追加Excel文件数据

Python如何覆盖与追加Excel文件数据

热心网友 时间:2026-05-11
转载

在Python数据分析工作中,Excel文件的读写操作是基础且频繁的任务。其中,覆盖写入与追加写入是两种最常见的需求场景。本文将系统讲解如何使用Python高效实现这两种操作,并分享不同应用场景下的最佳实践方案。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

python实现对excel的覆盖和追加操作

实现方式上,开发者主要可选择使用pandas库或openpyxl库。两者各有优势:pandas适合数据处理,openpyxl提供更精细的控制。下面通过具体代码示例详细说明。

一、覆盖写入(清空原文件内容,写入全新数据)

覆盖写入指每次执行代码时,目标文件中的原有数据会被完全替换为新内容。这种方法适用于生成全新报告或更新整个数据集的场景。

1.1 使用 pandas 实现覆盖写入

对于习惯使用pandas进行数据处理的开发者,这是最便捷的方法。DataFrameto_excel方法默认即为覆盖模式。

import pandas as pd
# 创建示例数据
data = {
    '姓名': ['张三', '李四', '王五'],
    '分数': [85, 92, 78]
}
df = pd.DataFrame(data)
# 覆盖写入(如果文件已存在会被覆盖)
df.to_excel('成绩表.xlsx', index=False, sheet_name='Sheet1')
print("覆盖写入完成")

代码简洁高效,一行to_excel即可完成。但需注意:如果原文件包含多个工作表,此方法会仅保留指定的Sheet1,其他所有工作表都将丢失

1.2 使用 openpyxl 实现覆盖写入

如需更精细控制或避免引入pandas,可直接使用openpyxl创建新工作簿并保存,同样实现覆盖效果。

from openpyxl import Workbook

# 创建新工作簿
wb = Workbook()
ws = wb.active
ws.title = "Sheet1"

# 写入表头和数据
ws.append(['姓名', '分数'])
ws.append(['张三', 85])
ws.append(['李四', 92])
ws.append(['王五', 78])

# 保存(覆盖)
wb.sa ve('成绩表.xlsx')
print("覆盖写入完成")

此方法同样创建全新文件。若成绩表.xlsx已存在,其所有内容(包括其他工作表)将被清空替换。

二、追加写入(保留原有数据,在末尾添加新行或新工作表)

追加写入需求更为复杂,主要分为两类:

  • 在现有工作表末尾追加新行:不破坏原有数据,仅续写内容。
  • 在同一文件中新增工作表:保留所有旧工作表,添加新Sheet。

2.1 使用 pandas + openpyxl 在现有工作表末尾追加行

pandasto_excel方法未提供直接的“追加行”参数,需通过其他方式实现。

方法一:先读取后合并再写入(适合数据量较小的情况)

核心思路:先读取旧数据,将其与新数据合并为新DataFrame,再一次性写回文件。这本质仍是覆盖写入,但覆盖内容为“旧数据+新数据”。

import pandas as pd
from openpyxl import load_workbook
# 原有文件路径
file_path = '成绩表.xlsx'
# 读取原有数据
try:
    df_old = pd.read_excel(file_path, sheet_name='Sheet1')
except FileNotFoundError:
    df_old = pd.DataFrame(columns=['姓名', '分数'])  # 如果文件不存在则创建空DataFrame
# 新数据
new_data = pd.DataFrame({'姓名': ['赵六', '小明'], '分数': [88, 95]})
# 合并
df_new = pd.concat([df_old, new_data], ignore_index=True)
# 写回文件(覆盖原文件,实际是替换整个内容)
df_new.to_excel(file_path, index=False, sheet_name='Sheet1')
print("追加写入完成")

此方法对小文件便捷,但若Excel文件较大或需频繁追加,反复读写整个文件将产生明显性能开销。

方法二:使用 openpyxl 直接追加(更高效,推荐)

openpyxl的优势在此凸显:可加载现有工作簿,直接定位到工作表末尾追加,完全不影响文件其他部分。

from openpyxl import load_workbook

file_path = '成绩表.xlsx'

# 加载工作簿
try:
    wb = load_workbook(file_path)
except FileNotFoundError:
    wb = Workbook()
ws = wb.active
if ws.title != 'Sheet1':
    ws.title = "Sheet1"

# 追加数据(假设已有表头,直接从下一行开始写)
new_rows = [
    ['赵六', 88],
    ['小明', 95]
]
for row in new_rows:
    ws.append(row)

wb.sa ve(file_path)
print("追加写入完成")

此方法高效安全,是追加行操作的首选方案。它不会影响其他工作表,性能远优于“先读后合再写”方式。

2.2 在现有 Excel 文件中新增工作表(不影响原有工作表)

如需添加全新工作表,可使用pandasExcelWriter在追加模式下优雅完成。

import pandas as pd
from openpyxl import load_workbook
file_path = '成绩表.xlsx'
# 新数据
df_new_sheet = pd.DataFrame({'科目': ['数学', '语文', '英语'], '成绩': [95, 88, 92]})
# 方法一:使用 pandas 的 ExcelWriter 添加新工作表
with pd.ExcelWriter(file_path, engine='openpyxl', mode='a', if_sheet_exists='replace') as writer:
    df_new_sheet.to_excel(writer, sheet_name='其他科目', index=False)
print("已新增工作表")

关键参数:mode='a'(追加模式)和engine='openpyxl'if_sheet_exists='replace'表示若存在同名工作表则替换;可设置为'new'避免覆盖。

三、核心操作总结与选择建议

为方便选择,将几种核心操作特点总结如下:

操作推荐方法特点
覆盖写入pd.DataFrame.to_excel()openpyxl.Workbook().sa ve()最简单,直接替换原文件
追加行openpyxlworksheet.append()不破坏原文件其他内容,性能较好
新增工作表pd.ExcelWriter(mode='a')保留原有工作表,添加新的 Sheet
完整追加(合并)pd.concat() + to_excel()适合少量数据,会重写整个文件

总体而言,若需频繁、大量执行追加行操作,直接使用openpyxl是性能最佳选择,可避免反复读写整个文件的开销。

四、综合应用示例

最后,通过一个综合示例演示如何结合覆盖与追加,灵活管理Excel文件中的多个工作表。

from openpyxl import Workbook, load_workbook

# 定义文件名和工作表名
filename = r"C:\Users\Administrator\Downloads\example.xlsx"

# 第一次写入(创建文件并写入两个sheet)
def first_write():
    # 加载或创建新工作簿
    try:
        wb = load_workbook(filename)
    except FileNotFoundError:
        wb = Workbook()
        wb.remove(wb.active)

    # 检查并删除已存在的 "作者" 工作表(如果存在)
    if "机构" in wb.sheetnames:
        del wb["机构"]
    sheet1 = wb.create_sheet("机构")
    for row in data1:
        sheet1.append(row)
    
    # 检查并删除已存在的 "作者" 工作表(覆盖/新建sheet)
    if "作者" in wb.sheetnames:
        del wb["作者"]
    sheet2 = wb.create_sheet("作者")
    for row in data2:
        sheet2.append(row)
    
    wb.sa ve(filename)

# 第二次写入(追加sheet)
def second_write():
    # 加载已存在的文件
    wb = load_workbook(filename)

    # 检查 "作者" 工作表是否存在,如果存在则获取它,否则创建一个新的
    if "作者" in wb.sheetnames:
        sheet2 = wb["作者"]
    else:
        sheet2 = wb.create_sheet("作者")
    for row in data3:
        sheet2.append(row)
    
    wb.sa ve(filename)

# 数据定义
data2 = [
    ['Header1', 'Header2', 'Header3'],
    [1, 2, 3],
    [4, 5, 6],
    [7, 8, 9]
]

data1 = [
    ['Header11', 'Header12', 'Header13'],
    [11, 2, 3],
    [41, 5, 6],
    [71, 8, 9]
]

data3 = [
    [21, 2, 3],
    [42, 5, 6],
    [73, 8, 9]
]

# 执行写入操作
first_write()  # 首次写入
second_write() # 覆盖写入

此示例清晰展示了如何利用openpyxl检查、删除、创建和追加工作表,实现对Excel文件结构的复杂控制。掌握这些基本模式,即可应对绝大多数Python操作Excel的读写需求。

来源:https://www.jb51.net/python/363434zag.htm

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Ubuntu系统下Java项目依赖管理方法与步骤详解

Ubuntu系统下Java项目依赖管理方法与步骤详解

在Ubuntu系统进行Java开发,需先安装OpenJDK及Maven或Gradle等构建工具。依赖管理主要通过项目的pom xml或build gradle文件声明。使用依赖树命令可分析冲突,并通过排除传递依赖或强制指定版本等方式解决。建议采用父POM版本管理或Gradle版本目录实现依赖版本统一。

时间:2026-05-11 08:29
Linux下Rust程序启动速度优化方法与技巧

Linux下Rust程序启动速度优化方法与技巧

优化Linux上Rust应用启动速度可从编译、依赖和加载等多方面入手。关键措施包括使用发布模式编译、精简依赖项、剥离调试信息、实现延迟加载以及利用并行编译。此外,可管理Cargo缓存、压缩二进制文件,并通过性能剖析定位瓶颈。代码优化、异步I O、静态链接及选用Musllibc等方法也能有效提升启动性能。

时间:2026-05-11 08:29
Python如何覆盖与追加Excel文件数据

Python如何覆盖与追加Excel文件数据

Python处理Excel文件时,覆盖写入和追加写入是常见需求。覆盖写入可使用pandas的to_excel方法或openpyxl创建新工作簿实现,直接替换原文件。追加写入分为在现有工作表末尾追加行和新增工作表两种情况。前者推荐使用openpyxl直接定位追加,高效且安全;后者可通过pandas的ExcelWriter在追加模式下完成,保留原有工作表。

时间:2026-05-11 08:28
IntelliJ IDEA Python代码提示优化方法与设置教程

IntelliJ IDEA Python代码提示优化方法与设置教程

IntelliJIDEA编写Python时,代码提示常不准确,导致运行时错误。优化方法包括:正确配置Python解释器、安装并启用Python插件、同步或重建项目索引、遵循PEP8规范保持代码清晰,以及定期更新IDEA至最新版本。通过调整这些配置与状态,可显著提升提示准确性和开发效率。

时间:2026-05-11 08:28
Ubuntu系统Java应用日志中文乱码问题解决方法

Ubuntu系统Java应用日志中文乱码问题解决方法

Ubuntu上部署Java应用时日志乱码多因编码不一致。主要成因包括JVM默认编码与系统不符、日志框架未设编码、源码文件编码非UTF-8及终端Locale配置不当。解决方法是在启动时指定JVM编码为UTF-8,或在日志框架配置中显式设置UTF-8,确保从源码到输出环境的整个链路统一使用UTF-8编码。

时间:2026-05-11 08:28
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程