6.27数据分析实训任务1.1(python)

import pandas as pd

import matplotlib.pyplot as plt

读取 CSV 文件

data = pd.read_csv(r"C:\Users\XXGC\Desktop\shiuxun3.csv")

将订单创建时间转换为 datetime 类型

data["订单创建时间"] = pd.to_datetime(data["订单创建时间"])

提取小时信息

data["小时"] = data["订单创建时间"].dt.hour

计算每个小时的订单数量

hourly_orders = data.groupby("小时")["订单编号"].count()

绘制折线图

plt.figure(figsize=(12, 6))

plt.plot(hourly_orders.index, hourly_orders.values)

plt.xlabel("小时")

plt.ylabel("订单数量")

plt.title("订单数量随时间的变化(小时维度)")

plt.xticks(range(0, 24, 2))

plt.grid(True)

plt.show()

数据分析

1. 订单数量最多的小时

max_hour = hourly_orders.idxmax()

max_orders = hourly_orders.max()

print("订单数量最多的小时是:{} 点,订单数量为:{}".format(max_hour, max_orders))

2. 总订单数量

total_orders = data["订单编号"].count()

print("总订单数量为:{}".format(total_orders))

3. 平均订单金额

average_amount = data["总金额"].mean()

print("平均订单金额为:{:.2f}".format(average_amount))

4. 退款订单数量和退款金额

refund_orders = data[data["退款金额"] > 0]

refund_orders_count = refund_orders.shape[0]

refund_amount = refund_orders["退款金额"].sum()

print("退款订单数量为:{},退款金额为:{:.2f}".format(refund_orders_count, refund_amount))

相关推荐
Boilermaker199211 分钟前
[Java 并发编程] Synchronized 锁升级
java·开发语言
沈浩(种子思维作者)17 分钟前
真的能精准医疗吗?癌症能提前发现吗?
人工智能·python·网络安全·健康医疗·量子计算
MM_MS27 分钟前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂1 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs1 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_991 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
io_T_T1 小时前
迭代器 iteration、iter 与 多线程 concurrent 交叉实践(详细)
python
古城小栈1 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
华研前沿标杆游学1 小时前
2026年走进洛阳格力工厂参观游学
python
Carl_奕然1 小时前
【数据挖掘】数据挖掘必会技能之:A/B测试
人工智能·python·数据挖掘·数据分析