簡體   English   中英

在不覆蓋數據的情況下向現有 excel 文件添加新行(Python)

[英]Add new row to existing excel file without overwriting the data (Python)

所以我將這段代碼從如何寫入現有的 excel 文件中復制而不覆蓋數據(使用熊貓)?

def append_df_to_excel(filename, df, sheet_name='Sheet1', startrow=None,
                   truncate_sheet=False, 
                   **to_excel_kwargs):
"""
Append a DataFrame [df] to existing Excel file [filename]
into [sheet_name] Sheet.
If [filename] doesn't exist, then this function will create it.

Parameters:
  filename : File path or existing ExcelWriter
             (Example: '/path/to/file.xlsx')
  df : dataframe to save to workbook
  sheet_name : Name of sheet which will contain DataFrame.
               (default: 'Sheet1')
  startrow : upper left cell row to dump data frame.
             Per default (startrow=None) calculate the last row
             in the existing DF and write to the next row...
  truncate_sheet : truncate (remove and recreate) [sheet_name]
                   before writing DataFrame to Excel file
  to_excel_kwargs : arguments which will be passed to `DataFrame.to_excel()`
                    [can be dictionary]

Returns: None
"""
from openpyxl import load_workbook

import pandas as pd

# ignore [engine] parameter if it was passed
if 'engine' in to_excel_kwargs:
    to_excel_kwargs.pop('engine')

writer = pd.ExcelWriter(filename, engine='openpyxl')

# Python 2.x: define [FileNotFoundError] exception if it doesn't exist 
try:
    FileNotFoundError
except NameError:
    FileNotFoundError = IOError


try:
    # try to open an existing workbook
    writer.book = load_workbook(filename)

    # get the last row in the existing Excel sheet
    # if it was not specified explicitly
    if startrow is None and sheet_name in writer.book.sheetnames:
        startrow = writer.book[sheet_name].max_row

    # truncate sheet
    if truncate_sheet and sheet_name in writer.book.sheetnames:
        # index of [sheet_name] sheet
        idx = writer.book.sheetnames.index(sheet_name)
        # remove [sheet_name]
        writer.book.remove(writer.book.worksheets[idx])
        # create an empty sheet [sheet_name] using old index
        writer.book.create_sheet(sheet_name, idx)

    # copy existing sheets
    writer.sheets = {ws.title:ws for ws in writer.book.worksheets}
except FileNotFoundError:
    # file does not exist yet, we will create it
    pass

if startrow is None:
    startrow = 0

# write out the new sheet
df.to_excel(writer, sheet_name, startrow=startrow, **to_excel_kwargs)

# save the workbook
writer.save()

function 所做的是:它將數據幀(行)添加到現有的 excel 文件中。 但是,此 function 正在替換原始 excel 文件的行,用於 dataframe 的行。 如何更改/添加到此 function 以使其首先插入行而不是替換行,從而維護原始數據並添加新數據?

# try to open an existing workbook writer.book = load_workbook(filename)

添加ws= writer.book[sheet_name] ws.insert_rows("number of the row you want to insert")

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM