Python——pd.pivot_table

2024-04-13 02:38
文章标签 python table pd pivot

本文主要是介绍Python——pd.pivot_table,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import pandas as pd
import time
import datetime
from dateutil.relativedelta import relativedelta
import numpy as npnow = datetime.datetime.now()   #现在的时间
last_d_0 = now + relativedelta(days = -1)  # 前 1 天——今天
last_d_1 = now + relativedelta(days = -3)  # 前 3 天—— 昨天业绩的前两天(今日)
last_d_2=  now + relativedelta(days = -4)  # 前 4 天—— 昨天业绩的前三天(昨日)
last_d_3 = now + relativedelta(days = -9)  # 前 9 天—— 前一周
last_d_4 = now + relativedelta(days= -16)  # 前 16天—— 前两周
last_d_5 = last_d_1+ relativedelta(months= -1)  #  前一月
last_d_6 = last_d_2+ relativedelta(months= -2)  #  前两月today = datetime.datetime.strftime(now,'%Y%m%d')
last_d_0 = datetime.datetime.strftime(last_d_0,'%Y%m%d')
last_d_1 = datetime.datetime.strftime(last_d_1,'%Y-%m-%d')
last_d_2 = datetime.datetime.strftime(last_d_2,'%Y-%m-%d')
last_d_3 = datetime.datetime.strftime(last_d_3,'%Y-%m-%d')
last_d_4 = datetime.datetime.strftime(last_d_4,'%Y-%m-%d')
last_d_5 = datetime.datetime.strftime(last_d_5,'%Y-%m-%d')
last_d_6 = datetime.datetime.strftime(last_d_6,'%Y-%m-%d')path = 'D:/众结资料/1日常工作内容/每日销售开发业绩(Python)/'+last_d_0+'/自定义sku报表本月.xlsx'
print(path)
path1 = 'D:/众结资料/1日常工作内容/每日销售开发业绩(Python)/'+last_d_0+'/自定义sku报表上月.xlsx'
path2 = '自定义sku报表本月.xlsx'fh = open(path , 'rb')
data_last_m_1 = pd.read_excel(fh,skiprows=[0, 1, 2, 3, 4])
data_last_m_1=data_last_m_1[data_last_m_1['平台']=='ebay']
data_last_m_1=data_last_m_1[data_last_m_1['订单类型']=='sale']fh1 = open(path1, 'rb')
data_last_m_2 = pd.read_excel(fh1,skiprows=[0, 1, 2, 3, 4])
data_last_m_2=data_last_m_2[data_last_m_2['平台']=='ebay']
data_last_m_2=data_last_m_2[data_last_m_2['订单类型']=='sale']fh2 = open(path2, 'rb')
data_last_m_3 = pd.read_excel(fh2,skiprows=[0, 1, 2, 3, 4])
data_last_m_3=data_last_m_3[data_last_m_3['平台']=='ebay']
data_last_m_3=data_last_m_3[data_last_m_3['订单类型']=='sale']result = pd.concat([data_last_m_2,data_last_m_1,data_last_m_3],axis=0)
result.drop_duplicates()
result.index  = range(len(result))
# result['时间'] = [datetime.datetime.strftime(datetime.datetime.strptime(result['付款时间'][i],'%Y-%m-%d %H:%M:%S'),'%Y-%m-%d') for i in range(len(result))]
result['时间'] = [datetime.datetime.strftime(result['付款时间'][i],'%Y-%m-%d') for i in range(len(result))]result_w_1 = result[result['时间'] >= last_d_3]
result_w_1 = result_w_1[result_w_1['时间'] <= last_d_1]
print("前一周订单"+last_d_3+" " +last_d_1)
result_w_1 = pd.pivot_table(result_w_1, index=['平台账号', '站点'], values=['订单总金额(包含客户运费、平台补贴)','数量'],aggfunc=np.sum, fill_value=0).reset_index()
result_w_1.to_excel('每日订单/前一周订单.xlsx',index=None)#前两周
result_w_2 = result[result['时间'] >= last_d_4]
result_w_2 = result_w_2 [result_w_2 ['时间'] < last_d_3]
print("前两周订单"+last_d_4+" " +last_d_3)
result_w_2 = pd.pivot_table(result_w_2, index=['平台账号', '站点'], values=['订单总金额(包含客户运费、平台补贴)','数量'],aggfunc=np.sum, fill_value=0).reset_index()
result_w_2.to_excel('每日订单/前两周订单.xlsx',index=None)# 今日订单
result_d_1 = result[result['时间'] >= last_d_1]
print("今日订单"+last_d_1)
result_d_1 = pd.pivot_table(result_d_1, index=['平台账号', '站点'], values=['订单总金额(包含客户运费、平台补贴)','数量'],aggfunc=np.sum, fill_value=0).reset_index()
result_d_1.to_excel('每日订单/今日订单.xlsx',index=None)#昨日订单
result_d_2 = result[result['时间'] >= last_d_2 ]
result_d_2 = result_d_2[result_d_2['时间'] < last_d_1 ]
print("昨日订单"+last_d_2)
result_d_2 = pd.pivot_table(result_d_2, index=['平台账号', '站点'], values=['订单总金额(包含客户运费、平台补贴)','数量'],aggfunc=np.sum, fill_value=0).reset_index()
result_d_2.to_excel('每日订单/昨日订单.xlsx',index=None)#前一个月订单
result_d_3 = result[result['时间'] >= last_d_5 ]
# result_d_3 = result_d_3[result_d_3['时间'] < last_d_1 ]
print("前一月订单"+last_d_5)
result_d_3 = pd.pivot_table(result_d_3, index=['平台账号'], values=['订单总金额(包含客户运费、平台补贴)'],aggfunc=[np.sum,len], fill_value=0).reset_index()
result_d_3.to_excel('每日订单/前一月订单.xlsx')#前两个月订单
result_d_4 = result[result['时间'] >= last_d_6 ]
result_d_4 = result_d_4[result_d_4['时间'] < last_d_5 ]
print("前两月订单"+last_d_6+" " +last_d_5)
result_d_4 = pd.pivot_table(result_d_4, index=['平台账号'], values=['订单总金额(包含客户运费、平台补贴)'],aggfunc=[np.sum,len], fill_value=0).reset_index()
result_d_4.to_excel('每日订单/前两月订单.xlsx')#前一个周站点每天订单
result_d_5 = result[result['时间'] >= last_d_3]
# result_d_3 = result_d_3[result_d_3['时间'] < last_d_1 ]
print("前一周站点每天订单"+last_d_5)
## python _ excel     index:行  columns:列  values:值  aggfunc:是求和还是次数、平均数
result_d_5 = pd.pivot_table(result_d_5, index=['站点','国家'], columns=['时间'],values=['订单总金额(包含客户运费、平台补贴)','毛利','平台账号'],aggfunc={"订单总金额(包含客户运费、平台补贴)":np.sum,"毛利":np.sum,"平台账号":len}, fill_value=0).reset_index()
result_d_5.to_excel('每日订单/前一周站点每天订单.xlsx')#前一个月每天订单
result_d_5 = result[result['时间'] > last_d_5 ]
# result_d_3 = result_d_3[result_d_3['时间'] < last_d_1 ]
print("前一月sku每天订单"+last_d_5)
result_d_5 = pd.pivot_table(result_d_5, index=['平台账号','站点'], columns=['时间'],values=['订单总金额(包含客户运费、平台补贴)'],aggfunc=[np.sum], fill_value=0).reset_index()
result_d_5.to_excel('每日订单/前一月sku每天订单.xlsx')

这篇关于Python——pd.pivot_table的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/898929

相关文章

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Python实现快速扫描目标主机的开放端口和服务

《Python实现快速扫描目标主机的开放端口和服务》这篇文章主要为大家详细介绍了如何使用Python编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

Python轻松实现Word到Markdown的转换

《Python轻松实现Word到Markdown的转换》在文档管理、内容发布等场景中,将Word转换为Markdown格式是常见需求,本文将介绍如何使用FreeSpire.DocforPython实现... 目录一、工具简介二、核心转换实现1. 基础单文件转换2. 批量转换Word文件三、工具特性分析优点局

Python中4大日志记录库比较的终极PK

《Python中4大日志记录库比较的终极PK》日志记录框架是一种工具,可帮助您标准化应用程序中的日志记录过程,:本文主要介绍Python中4大日志记录库比较的相关资料,文中通过代码介绍的非常详细,... 目录一、logging库1、优点2、缺点二、LogAid库三、Loguru库四、Structlogphp

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

Python海象运算符:=的具体实现

《Python海象运算符:=的具体实现》海象运算符又称​​赋值表达式,Python3.8后可用,其核心设计是在表达式内部完成变量赋值并返回该值,从而简化代码逻辑,下面就来详细的介绍一下如何使用,感兴趣... 目录简介​​条件判断优化循环控制简化​推导式高效计算​正则匹配与数据提取​性能对比简介海象运算符

python项目环境切换的几种实现方式

《python项目环境切换的几种实现方式》本文主要介绍了python项目环境切换的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 如何在不同python项目中,安装不同的依赖2. 如何切换到不同项目的工作空间3.创建项目

python项目打包成docker容器镜像的两种方法实现

《python项目打包成docker容器镜像的两种方法实现》本文介绍两种将Python项目打包为Docker镜像的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录简单版:(一次成功,后续下载对应的软件依赖)第一步:肯定是构建dockerfile,如下:第二步

Python + Streamlit项目部署方案超详细教程(非Docker版)

《Python+Streamlit项目部署方案超详细教程(非Docker版)》Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,:本文主要介绍Python+St... 目录一、针对 Alibaba Cloud linux/Centos 系统的完整部署方案1. 服务器基础配置(阿里