[解決済み] Pandasを使って、既存のExcelファイルに新しいシートを保存する方法は?
2022-07-10 04:11:04
質問
pythonで作成したデータをExcelファイルに保存したい。私の問題は、既存の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つのDataFrameを2つのシートに保存し、それぞれ"x1"と"x2"と名付けました。2 つの新しい DataFrame を作成し、同じコードを使用して 'x3' と 'x4' という 2 つの新しいシートを追加しようとすると、元のデータが失われます。
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()
4つのシートからなるエクセルファイルが欲しい。x1'、'x2'、'x3'、'x4'の4つのシートからなるExcelファイルが欲しいのです。 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"を追加するにはどの方法が良いでしょうか?
どのように解決するのですか。
ありがとうございます。私は完全な例は、同じ問題を持っている他の誰にとっても良いことができると信じています。
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()
私の理解では、それが "xslxwriter" または "openpyxl" エンジンのどちらで生成されたものであっても問題ではありません。
元のデータを失うことなく書き込みを行いたい場合。
import pandas as pd
import numpy as np
from openpyxl import load_workbook
path = r"C:\Users\fedel\Desktop\excelData\PhD_data.xlsx"
book = load_workbook(path)
writer = pd.ExcelWriter(path, engine = 'openpyxl')
writer.book = book
x3 = np.random.randn(100, 2)
df3 = pd.DataFrame(x3)
x4 = np.random.randn(100, 2)
df4 = pd.DataFrame(x4)
df3.to_excel(writer, sheet_name = 'x3')
df4.to_excel(writer, sheet_name = 'x4')
writer.save()
writer.close()
このコードで完了です
関連
-
[解決済み] Pythonで辞書に新しいキーを追加するにはどうすればよいですか?
-
[解決済み] PandasでDataFrameの行を反復処理する方法
-
[解決済み] ファイルのコピー方法について教えてください。
-
[解決済み] Pythonでファイルやフォルダを削除する方法は?
-
[解決済み] Pandas DataFrameの行数を取得する方法は?
-
[解決済み] Matplotlibでプロットを表示するのではなく、画像ファイルに保存する。
-
[解決済み] 既存のDataFrameに新しい列を追加する方法は?
-
[解決済み] pandasを使った "大量データ "ワークフロー【終了しました
-
[解決済み] Pythonでマルチプロセッシングキューを使うには?
-
[解決済み] PILでPNG画像を文字列に書き出すには?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] 既存のExcelファイルにデータを上書きせずに書き込むには(pandasを使用)?
-
[解決済み] 文字列のリストを内容に基づいてフィルタリングする
-
[解決済み] Ctrl-CでPythonスクリプトを終了できない
-
[解決済み] Pythonでマルチプロセッシングキューを使うには?
-
[解決済み] PyQtアプリケーションのスレッド化。QtスレッドとPythonスレッドのどちらを使うか?
-
[解決済み] djangoフレームワークでフォームフィールドから値を取得するには?
-
[解決済み] models.pyを複数のファイルに分割する
-
[解決済み] python: 2階層上のディレクトリを取得する
-
[解決済み] リストスライスの割り当てはどのように行われるのですか?
-
[解決済み] Pythonを使ってすべてのASCII文字のリストを得るにはどうすればよいですか?