kuyoro 2022-03-25 03:57 采纳率: 90.5%
浏览 77
已结题

怎么通过通过pandas 的pivot_table对多列多行进行转置汇总

数据库表格如下:

ts_codeend_datebz_itembz_salesbz_profitbz_costcurr_typeupdate_flag
600002.SH20191231中国大陆1102.81204.55898.26CNY0
600002.SH20191231国外172.2836.97135.31CNY0
600002.SH20200630中国大陆439.4037900CNY0
600002.SH20200630国外92.9642900CNY0
600002.SH20201231中国大陆1156.44176.02980.42CNY0
600002.SH20201231国外216.4156.55159.86CNY0
600002.SH20201231其他业务(地区)0.000560.78751-0.78695CNY0
600002.SH20210630中国大陆508.9319800CNY0
600002.SH20210630国外116.3451400CNY0

希望通过pandas转成如下:

ts_codebz_itemITEM20191231202006302020123120210630
600002.SH中国大陆bz_sales1102.81439.40379216.41508.93198
600002.SH中国大陆bz_profit204.55056.550
600002.SH中国大陆bz_cost898.260159.860
600002.SH国外bz_sales172.2892.964290.00056116.34514
600002.SH国外bz_profit36.9700.787510
600002.SH国外bz_cost135.310-0.786950

python语句如下:

    sql = """
             SELECT ts_code,end_date,bz_item,bz_sales,bz_profit,bz_cost,curr_type,update_flag
            FROM fina_mainbz_p where ts_code ='600002.SH' order by end_date asc
            """
    print(sql)
    df = pd.read_sql_query(sql, engine_ts)
    new_df = pd.pivot_table(df, columns='end_date', values=item_list)
    new_df = new_df.rename_axis([None], axis=1).reset_index().rename(
        columns={'index': 'ITEM'}).set_index(['ITEM'])

    # 增加 产品或地区bz_item字段
    new_df = new_df.rename_axis([None], axis=1).reset_index().rename(
        columns={'index': 'ITEM'}, index=df['bz_item'][:len(new_df)])

    print(new_df)

    # 保存到csv
    new_df.to_csv(r"D:/Personal/Desktop/ts_" +
                  str(int(time.time())) + ".csv", encoding='utf_8_sig')

但无法达到想要的输出结果,不知道pivot_table该怎么操作?

展开全部

  • 写回答

2条回答 默认 最新

  • 有问必答小助手 2022-03-28 10:03
    关注

    你好,我是有问必答小助手,非常抱歉,本次您提出的有问必答问题,技术专家团超时未为您做出解答


    本次提问扣除的有问必答次数,已经为您补发到账户,我们后续会持续优化,扩大我们的服务范围,为您带来更好地服务。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 4月8日
  • 已采纳回答 4月1日
  • 创建了问题 3月25日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部