Pandas:在原Excel表中追加写入数据,不覆盖

一、需求

1、将dict类型的数据追加写入到现有的Excel中

2、将list[dict]类型的数据追加写入到现有的Excel中

二、方法

见代码

三、代码

import pandas as pd
from openpyxl import load_workbook


# 将dict类型的数据追加写入到现有的Excel中
def write_to_exist_excel1(fileName, sheetName):
    df_old = pd.DataFrame(pd.read_excel(fileName, sheet_name=sheetName))  # 读取原数据文件和表
    row_old = df_old.shape[0]  # 获取原数据的行数

    data_added = {"a": 99, "b": 98, "c": 97}
    df = pd.DataFrame(data_added, index=[0])  # 如果dict的value只有一行,加上index = [0]即可

    book = load_workbook(fileName)
    writer = pd.ExcelWriter(fileName, engine='openpyxl')
    writer.book = book
    writer.sheets = dict((ws.title, ws) for ws in book.worksheets)

    # 将data_added数据写入Excel中
    df.to_excel(writer, sheet_name=sheetName, startrow=row_old + 1, index=False, header=False)

    writer.save()  # 保存


# 将list[dict]类型的数据追加写入到现有的Excel中
def write_to_exist_excel2(fileName, sheetName):
    df_old = pd.DataFrame(pd.read_excel(fileName, sheet_name=sheetName))  # 读取原数据文件和表
    row_old = df_old.shape[0]  # 获取原数据的行数

    data_added = [{"a": 9, "b": 8, "c": 7, "d": 6},
                  {"a": 37, "b": 38, "c": 39, "d": 40}]
    df = pd.DataFrame(data_added)

    book = load_workbook(fileName)
    writer = pd.ExcelWriter(fileName, engine='openpyxl')
    writer.book = book
    writer.sheets = dict((ws.title, ws) for ws in book.worksheets)

    # 将data_added数据写入Excel中
    df.to_excel(writer, sheet_name=sheetName, startrow=row_old + 1, index=False, header=False)

    writer.save()  # 保存


if __name__ == '__main__':
    fileName = 'test.xlsx'
    sheetName = 'Sheet1'
    write_to_exist_excel1(fileName, sheetName)
    write_to_exist_excel2(fileName, sheetName)

四、结果

1、原始Excel文件如下

2、修改后的Excel文件如下

五、参考

(1)文章:pandas to_excel:写入数据,在同一个sheet中追加数据,写入到多个sheet里

(2)报错参考文章:Python错误 ValueError: If using all scalar values, you must pass an index.

  • 12
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值