kuyoro 2022-03-25 11:57 采纳率: 92.7%
浏览 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 18:03
    关注

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


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

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

报告相同问题?

问题事件

  • 系统已结题 4月9日
  • 已采纳回答 4月1日
  • 创建了问题 3月25日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效