首页 > 解决方案 > 为什么此代码会导致 excel 中按字母顺序排列的列列表?

问题描述

table = pd.pivot_table(gains,
                       index=['Account', 'Date', 'Security'],
                       values=['Units', 'Proceeds', 'ACB', 'Gain(Loss)'])

# pivot table for gains(losses) broken down by investment account

for account in table.index.get_level_values(0).unique():
    # print gains losses sheets one summary for each investment account
    temp_df = table.xs(account, level=0)
    # column_titles = ['Units', 'Proceeds', 'ACB', 'Gain(Loss)']
    # temp_df.reindex(columns=column_titles)
    s_name = account + ' - ' + str(idate.year)
    temp_df.to_excel(writer, sheet_name=s_name,
                     columns=['Units', 'Proceeds', 'ACB', 'Gain(Loss)'])

第一个 Excel 表显示了增益数据框的正确列顺序:

即账户日期安全单位收益 ACB 收益(损失)

但是各个 temp.df 数据框创建具有以下列顺序的 excel 表:

即日期证券 ACB 收益(损失)收益单位

请注意,在 Date 和 Security 列之后,即使我的代码中有 columns=[] 参数,这些列也是按字母顺序排列的。这似乎在一段时间内正常工作,然后突然恢复为“Units Proceeds ACB and Gain(Loss)”的字母顺序

任何帮助将非常感激。

编辑:数据框中的顺序是“Account Date Security Units Proceeds ACB Gain(Loss)”,但 to_excel 程序似乎从“Units”开始按字母顺序排列。

Edit2:或者,按我想要的顺序获取这些列的最佳方法是什么。我应该使用 openpyxl、xlrd、xlwt 还是我想要的不是真的可能?

标签: pythonexcelpython-3.xpandasdataframe

解决方案


我用以下方法解决了这个问题:

s_name = account + ' - ' + str(idate.year)
            temp_df = temp_df[['Units', 'Proceeds', 'ACB', 'Gain(Loss)']]
            temp_df.to_excel(writer, sheet_name=s_name,
                             columns=['Units', 'Proceeds', 'ACB', 'Gain(Loss)'])

推荐阅读