Старе питання, але я здогадуюсь, що деякі люди все ще шукають цього - так ...
Я вважаю цей метод приємним, оскільки всі робочі таблиці завантажуються у словник імен аркушів та пар даних, створених пандами з назвою аркуша = Немає параметра. Додавати, видаляти або змінювати робочі таблиці між елементами читання електронної таблиці у формат диктату просто не можна. Для мене xlsxwriter працює краще, ніж openpyxl для цього конкретного завдання з точки зору швидкості та формату.
Примітка: майбутні версії панд (0.21.0+) змінять параметр "name name" на "sheet_name".
# read a single or multi-sheet excel file
# (returns dict of sheetname(s), dataframe(s))
ws_dict = pd.read_excel(excel_file_path,
sheetname=None)
# all worksheets are accessible as dataframes.
# easy to change a worksheet as a dataframe:
mod_df = ws_dict['existing_worksheet']
# do work on mod_df...then reassign
ws_dict['existing_worksheet'] = mod_df
# add a dataframe to the workbook as a new worksheet with
# ws name, df as dict key, value:
ws_dict['new_worksheet'] = some_other_dataframe
# when done, write dictionary back to excel...
# xlsxwriter honors datetime and date formats
# (only included as example)...
with pd.ExcelWriter(excel_file_path,
engine='xlsxwriter',
datetime_format='yyyy-mm-dd',
date_format='yyyy-mm-dd') as writer:
for ws_name, df_sheet in ws_dict.items():
df_sheet.to_excel(writer, sheet_name=ws_name)
Для прикладу у питанні 2013 року:
ws_dict = pd.read_excel('Masterfile.xlsx',
sheetname=None)
ws_dict['Main'] = data_filtered[['Diff1', 'Diff2']]
with pd.ExcelWriter('Masterfile.xlsx',
engine='xlsxwriter') as writer:
for ws_name, df_sheet in ws_dict.items():
df_sheet.to_excel(writer, sheet_name=ws_name)