ฉันต้องการใช้ไฟล์ 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()
รหัสนี้จะบันทึก DataFrames สองแผ่นลงในแผ่นงานสองแผ่นชื่อ "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"