我想使用 excel 文件来存储用 python 进行详细说明的数据。我的问题是我不能将工作表添加到现有的 Excel 文件。在这里,我建议使用一个示例代码来解决这个问题
import pandas as pd
import numpy as np
path = r"C:\Users\fedel\Desktop\excelData\PhD_data.xlsx"
x1 = np.random.randn(100, 2)
df1 = pd.DataFrame(x1)
x2 = np.random.randn(100, 2)
df2 = pd.DataFrame(x2)
writer = pd.ExcelWriter(path, engine = 'xlsxwriter')
df1.to_excel(writer, sheet_name = 'x1')
df2.to_excel(writer, sheet_name = 'x2')
writer.save()
writer.close()
这段代码将两个 DataFrame 保存到两个工作表中,分别命名为“ x1”和“ x2”。如果我创建两个新的 DataFrames 并尝试使用相同的代码添加两个新的工作表,‘ x3’和‘ x4’,则原始数据将丢失。
import pandas as pd
import numpy as np
path = r"C:\Users\fedel\Desktop\excelData\PhD_data.xlsx"
x3 = np.random.randn(100, 2)
df3 = pd.DataFrame(x3)
x4 = np.random.randn(100, 2)
df4 = pd.DataFrame(x4)
writer = pd.ExcelWriter(path, engine = 'xlsxwriter')
df3.to_excel(writer, sheet_name = 'x3')
df4.to_excel(writer, sheet_name = 'x4')
writer.save()
writer.close()
我想要一个 Excel 文件有四个表: ‘ x1’,‘ x2’,‘ x3’,‘ x4’。 我知道“ xlsxwriter”不是唯一的“引擎”,还有“ openpyxl”。我也看到已经有其他人写了这个问题,但我仍然不明白如何做到这一点。
这是从 链接中提取的代码
import pandas
from openpyxl import load_workbook
book = load_workbook('Masterfile.xlsx')
writer = pandas.ExcelWriter('Masterfile.xlsx', engine='openpyxl')
writer.book = book
writer.sheets = dict((ws.title, ws) for ws in book.worksheets)
data_filtered.to_excel(writer, "Main", cols=['Diff1', 'Diff2'])
writer.save()
他们说这种方法有效,但是很难弄清楚它是如何起作用的。我不明白“ ws.title”、“ ws”和“ dict”在这个上下文中是什么意思。
保存“ x1”和“ x2”,然后关闭文件,再次打开并添加“ x3”和“ x4”的最佳方法是什么?