私はPythonで精巧なデータを保存するためにExcelファイルを使いたいと思っています。私の問題は、既存のExcelファイルにシートを追加できないことです。ここで私はPandasを使用して既存の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()
にこのコードを、この問題に到達するためにで動作するように、サンプルコードを示唆してそれぞれ2枚の「X1」という名前のシート、および「X2」には、2つのデータフレームが保存されます。 2つの新しいDataFramesを作成し、同じコードを使用して2つの新しいシート '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()
「x1」、「x2」、「x3」、「x4」の4つのシートでExcelファイルが必要です。 「xlsxwriter」は唯一の「エンジン」ではないことがわかっています。「openpyxl」があります。私はまた、すでにこの問題について書いた他の人たちがいるのを見ましたが、それをどうやって行うのか分かりません。ここで
このlink
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」を追加する最も良い方法はどれですか?
[this](http://xlsxwriter.readthedocs.io/working_with_pandas.html)に似たもっと「パンダ」の例を追加できたら本当に助かります。 – MaxU
私はパンダで多くの作業をしません私は実際に多くの例を提供することはできませんが、ドキュメントの改善を歓迎します。 –