全栈式数据统计:Flask+Pandas 怎样替换键名称

话不多说,有图有源码:

1.先看效果

2.实现代码

复制代码
from flask import Flask, render_template
import pandas as pd

app = Flask(__name__)

# 自定义千分位格式化函数
def format_thousands(x):
    return f'{x:,.2f}'

@app.route('/')
def show_dataframe():
    path = r'F:\test_data\年度销售数据\2023年度销售数据.xlsx'
    data = pd.read_excel(path, engine='openpyxl')
    data['报审日期'] = pd.to_datetime(data['报审日期'])
    columstype='季度'
    if columstype=='年':
        columstype_data = data['报审日期'].dt.year
    elif columstype=='季度':
        columstype_data = data['报审日期'].dt.quarter
    else:
        columstype_data = data['报审日期'].dt.month
    # print(f"{type(month)},{month}")
    # data['办事处部门_List'] = data['办事处部门'].apply(lambda x: x.tolist())
    # data['事业部_List'] = data['事业部'].apply(lambda x: x.tolist())

    # # 定义一个字典,将旧的key映射到新的key
    # rename_dict = {
    #     1: '1月',
    #     2: '2月',
    #     3: '3月',
    #     4: '4月',
    #     5: '5月',
    #     6: '6月',
    #     7: '7月',
    #     8: '8月',
    #     9: '9月',
    #     10: '10月',
    #     11: '11月',
    #     12: '12月',
    # }

    data2 = pd.pivot_table(data, index=['事业部','办事处部门'], values='合同金额', columns=columstype_data,
                           aggfunc=sum).fillna(0)  # ,'办事处部门',fill_value='无',合计字段 , margins=True, margins_name='Total'
    # -------数值千分位格式化
    data2 = data2.applymap(format_thousands)  #

    # 获取dataframe的键名,并将它们作为列表返回
    column_names = data2.columns.tolist()
    rename_dict ={}
    for i,num in enumerate(column_names):
        rename_dict[num]=str(num)+str(columstype)
    # print(column_names,rename_dict)
    data2 =data2.rename(columns=rename_dict)
    # 使用rename方法替换DataFrame中的key名称
    # data2.rename(columns=rename_dict, inplace=True)
    # print(data2)

    # 将DataFrame转换为HTML
    html = data2.to_html() #index=False
    return render_template('test.html', table=html)


if __name__ == '__main__':
    app.run(debug=True)

3.关注实现内容:

说明:

1)用df.columns.tolist()获取键列表

2)替换键名称: df.rename(columns=rename_dict)

其他请参考:

全栈式数据统计:Flask+Pandas按年,季度,月统计显示

对你有所帮助,请点个赞吧!

相关推荐
哥本哈士奇(aspnetx)14 小时前
Streamlit + LangChain 1.0 简单实现智能问答前后端
python·大模型
我一定会有钱14 小时前
斐波纳契数列、end关键字
python
小鸡吃米…15 小时前
Python 列表
开发语言·python
星依网络16 小时前
yolov5实现游戏图像识别与后续辅助功能
python·开源·游戏程序·骨骼绑定
大佐不会说日语~16 小时前
Spring AI Alibaba 的 ChatClient 工具注册与 Function Calling 实践
人工智能·spring boot·python·spring·封装·spring ai
2501_9216494917 小时前
如何获取美股实时行情:Python 量化交易指南
开发语言·后端·python·websocket·金融
qq_4480111617 小时前
python HTTP请求同时返回为JSON的异常处理
python·http·json
棒棒的皮皮17 小时前
【OpenCV】Python图像处理几何变换之翻转
图像处理·python·opencv·计算机视觉
CodeCraft Studio17 小时前
国产化PPT处理控件Spire.Presentation教程:使用Python将图片批量转换为PPT
python·opencv·powerpoint·ppt文档开发·ppt组件库·ppt api
五阿哥永琪18 小时前
Spring Boot 中自定义线程池的正确使用姿势:定义、注入与最佳实践
spring boot·后端·python