调整pandas dataframe输出到excel的工作表worksheet顺序

当使用Pandas将数据写入Excel并涉及多个工作表时,原始顺序可能不符合需求。解决办法是预先创建空表以设定顺序,如创建ABCDE顺序的工作表,然后再追加写入实际数据。这样即使写入顺序不同,最终结果也会按照预设的顺序排列。例如,先写入空数据到所有工作表,然后按需对每个工作表追加排序后的数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用pandas将数据输出到excel时,如果存在多个工作表,先输出的工作表会生成在前面,后输出的会在生成后面,通过pandas无法直接对工作表进行排序

例如输出的worksheet的顺序是BCDAE,而希望最终呈现的顺序是ABCDE,通过pandas是无法对其排序的

探索出一种可行的办法是预先写入空表ABCDE

writer1 = pd.ExcelWriter(outputpath)
dft = pd.DataFrame()
dft.to_excel(writer1, "A")
dft.to_excel(writer1, "B")
dft.to_excel(writer1, "C")
dft.to_excel(writer1, "D")
dft.to_excel(writer1, "E")

这样生成的excel就会以ABCDE的顺序生成,而且以后不会再改变

然后将数据通过同一excelwriter追加写入对应表即可,这里以排序结果为例

df2.sort_values(by='综合抛料率‰', ascending=False).to_excel(writer1, sheet_name='B', startcol=0, startrow=0,index=False)
df2.sort_values(by='综合抛料率‰', ascending=False).to_excel(writer1, sheet_name='C', startcol=0, startrow=0,index=False)
df2.sort_values(by='综合抛料率‰', ascending=False).to_excel(writer1, sheet_name='D', startcol=0, startrow=0,index=False)
df2.sort_values(by='综合抛料率‰', ascending=False).to_excel(writer1, sheet_name='A', startcol=0, startrow=0,index=False)
df2.sort_values(by='综合抛料率‰', ascending=False).to_excel(writer1, sheet_name='E', startcol=0, startrow=0,index=False)

虽然是按BCDAE的顺序输出的,但是最终呈现结果是ABCDE

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值