首页 > 编程问答 >尝试创建一个条形图,显示按性别和日期分组的每次购买所花费的总金额

尝试创建一个条形图,显示按性别和日期分组的每次购买所花费的总金额

时间:2024-07-31 03:56:10浏览次数:10  
标签:python

我正在尝试创建一个条形图来回答以下问题:哪种性别每年花的钱最多?我有一个数据集,其中列出了每笔交易,并附有每个条目所花费的金额、性别(男性、女性、其他)和日期(2014 年 10 月 16 日、2015 年 9 月 8 日、2016 年 7 月 29 日等) 。我想创建一个条形堆叠条形图,显示每年(仅当年)每个性别的支出总额。请帮忙!

    THIS IS WHAT I HAVE SO FAR (Doesn't work):
    import pandas as pd 
    import numpy as np
    import matplotlib.pyplot as plt
    import seaborn as sns
    sns.set(style = "white", color_codes=True)
    sales = pd.read_csv("/kaggle/input/mobile-sales-dataset/mobile_sales.csv")

   
    sales.groupby(['CustomerGender'])['TotalRevenue'].sum()
    genders =["Male","Female","Other"]
    w = 0.2
    xp = range(len(genders))

    plt.bar(xp,genders)
    #p1 = plt.bar(bar1, male, w, label = "Male")
    #p2 = plt.bar(bar2, female, w, label = "Female")
    #p3 = plt.bar(bar3, other, w, label = "Other")

    plt.ylabel('Total Revenue')
    plt.title('Total Revenue by Gender')
    plt.xticks(xp,x)
    plt.legend()
    plt.show()
```

需要做的第一件事是从“购买日期”列中提取年份信息,然后才能根据年份和性别对数据进行分组。以下是如何使用 Pandas 和 Seaborn 在 Python 中创建所需条形图的方法:

import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns

# 从 csv 文件加载数据
sales = pd.read_csv("/kaggle/input/mobile-sales-dataset/mobile_sales.csv")

# 将“Purchase Date”列转换为日期时间对象
sales['Purchase Date'] = pd.to_datetime(sales['Purchase Date'])

# 从“Purchase Date”列中提取年份
sales['Year'] = sales['Purchase Date'].dt.year

# 按年份和性别对数据进行分组,并计算每个组的总收入
grouped_sales = sales.groupby(['Year', 'Customer Gender'])['Total Revenue'].sum().reset_index()

# 创建堆叠条形图
plt.figure(figsize=(10, 6))
sns.barplot(x='Year', y='Total Revenue', hue='Customer Gender', data=grouped_sales)
plt.xlabel('年份')
plt.ylabel('总收入')
plt.title('每年按性别划分的总收入')
plt.show()

此代码首先将“Purchase Date”列转换为日期时间对象,然后使用该对象提取年份信息。然后,它按年份和性别对数据进行分组,并计算每个组的总收入。最后,它使用 Seaborn 的 barplot 函数创建一个堆叠条形图,该函数显示每年每个性别的总支出。

此图将帮助回答哪个性别每年花费最多的问题。

标签:python
From: 78813444

相关文章

  • 基于遗传(GA)、粒子群(PSO)、模拟退火(SA)、禁忌搜索(ST)、蚁群算法(ACO)、自自组织神
        ......
  • 10个append()函数在Python程序开发中的创新应用
    文末赠免费精品编程资料~~在Python编程的世界里,append()函数是列表操作中最常见的方法之一。它允许我们在列表的末尾添加一个元素,这一简单的功能却能激发无限的创造力。今天,我们将探讨append()函数在Python程序开发中的10种创新应用,从基本用法到高级技巧,逐步深入。1.构......
  • 全网最适合入门的面向对象编程教程:28 类和对象的Python实现-Python编程原则、哲学和规
    全网最适合入门的面向对象编程教程:28类和对象的Python实现-Python编程原则、哲学和规范大汇总摘要:本文主要介绍了在使用Python进行面向对象编程时,Python异常处理的原则-“请求谅解,而非许可”,以及软件设计和Python的编程原则,同时介绍了PEP8规范。原文链接:FreakStud......
  • python生成器
    一前言环境:python3.10win10二生成器1关于生成器先看一个例子    定义了一个函数,当我们运行该函数时,并未像普通函数那样执行函数体内的代码    从其中的英文可知,执行函数得到了一个生成器对象,这个生成器对象也叫做generatoriterator(生成器迭代器),generatorit......
  • 生成MySQL-oracle-SQL server数据字典(附Python代码)
    生成数据字典,早年写的,请注意新的版本变化。(1)MySQL元数据SQLUSEinformation_schema;#取出库和表。select  TABLE_SCHEMAAS'数据库名称',  TABLE_NAMEAS'表名',  TABLE_TYPEAS'表类型',  ROW_FORMATAS'行格式',  ENGINEAS'数据库引擎',  TABL......
  • Python - Method Resolution Order (MRO)
    TheorderinwhichPythonsearchesforattributesinbaseclassesiscalledmethodresolutionorder(MRO).Itgivesalinearizedpathforaninheritancestructure.PythoncomputesanMROforeveryclassinthehierarchy;thisMROiscomputedusingthe‘C3......
  • 计算机毕业设计选题推荐-零食批发商仓库管理系统-Java/Python项目实战
    ✨作者主页:IT研究室✨个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。☑文末获取源码☑精彩专栏推荐⬇⬇⬇Java项目Python项目安卓项目微信小程序项目......
  • 【自动化测试必学语言】python:语言基础
    目录Python介绍语言的分类注释单行注释多行注释变量定义变量使用变量变量名的命名规范数据类型数字类型非数字类型type()函数input输入print输出格式化输出快捷键(小操作)运算符算术运算符 比较运算符Python介绍作者:吉多·范罗苏姆(Guidov......
  • Python基础知识笔记——常用函数
    一、range()函数range()函数用于生成一个整数序列。它通常用于循环结构中,例如for循环,以提供循环的迭代次数。range()函数可以有1到3个参数。#range(start,stop,step)range(2,6,2)#生成从2开始,到6结束(不包括6),步长为2的一串数字#参数指定不完全时,默认从0开始,步长......
  • [python] 启发式算法库scikit-opt使用指北
    scikit-opt是一个封装了多种启发式算法的Python代码库,可以用于解决优化问题。scikit-opt官方仓库见:scikit-opt,scikit-opt官网文档见:scikit-opt-doc。scikit-opt安装代码如下:pipinstallscikit-opt#调用scikit-opt并查看版本importskosko.__version__'0.6.6'0背景介......