python写入excel多个sheet表 以及追加sheet表

python写入excel多个sheet表 以及追加sheet表

可将不同DataFrame分别写入指定Sheet(如初始写入"箱_4"和"箱_2"),并通过封装函数append_to_excel支持动态追加新Sheet到现有文件,自动处理Sheet名重复问题(如重复时生成"新数据表_副本1")

写入多个sheet表

python 复制代码
import pandas as pd


# 创建 ExcelWriter 对象(指定引擎为 openpyxl)
with pd.ExcelWriter('汇总.xlsx', engine='openpyxl') as writer:
    # 将原始数据写入 Sheet 名 "原始数据"
    df.to_excel(writer, sheet_name='箱_4', index=False)
    
    # 将去重后数据写入 Sheet 名 "去重数据"
    df.to_excel(writer, sheet_name='箱_2', index=False)

print("数据已保存到不同 Sheet 中!")

在excel追加sheet表

python 复制代码
import pandas as pd
import os

def append_to_excel(df, file_path, sheet_name):
    """
    将 DataFrame 追加到 Excel 文件的新 Sheet 中,自动处理 Sheet 名重复问题
    参数:
        df: 要保存的 DataFrame
        file_path: Excel 文件路径 (e.g., 'data.xlsx')
        sheet_name: 新 Sheet 的名称
    """
    # 判断文件是否存在,决定写入模式
    mode = 'a' if os.path.exists(file_path) else 'w'
    
    with pd.ExcelWriter(file_path, engine='openpyxl', mode=mode) as writer:
        # 处理 Sheet 名重复
        if mode == 'a':
            existing_sheets = writer.book.sheetnames  # 获取现有 Sheet 名列表
            new_sheet_name = sheet_name
            counter = 1
            while new_sheet_name in existing_sheets:
                new_sheet_name = f"{sheet_name}_副本{counter}"
                counter += 1
            sheet_name = new_sheet_name  # 更新为唯一 Sheet 名
        df.to_excel(writer, sheet_name=sheet_name, index=False)
    
    print(f"数据已追加到 Sheet: '{sheet_name}'")

# 使用示例
df = pd.DataFrame({'数据列': [1, 2, 3]})
append_to_excel(df, '汇总.xlsx', '新数据表')
相关推荐
Python图像识别1 小时前
71_基于深度学习的布料瑕疵检测识别系统(yolo11、yolov8、yolov5+UI界面+Python项目源码+模型+标注好的数据集)
python·深度学习·yolo
QX_hao1 小时前
【Go】--map和struct数据类型
开发语言·后端·golang
你好,我叫C小白1 小时前
C语言 循环结构(1)
c语言·开发语言·算法·while·do...while
千码君20162 小时前
React Native:从react的解构看编程众多语言中的解构
java·javascript·python·react native·react.js·解包·解构
淮北4942 小时前
windows安装minicoda
windows·python·conda
Evand J3 小时前
【MATLAB例程】基于USBL和DVL的线性回归误差补偿,对USBL和DVL导航数据进行相互补偿,提高定位精度,附代码下载链接
开发语言·matlab·线性回归·水下定位·usbl·dvl
lied16636348063 小时前
List导出到Excel文件
servlet·list·excel
爱喝白开水a4 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
Neverfadeaway4 小时前
【C语言】深入理解函数指针数组应用(4)
c语言·开发语言·算法·回调函数·转移表·c语言实现计算器
武子康4 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql