Pandas高级数据分析快速入门之四——数据可视化篇

Pandas高级数据分析快速入门之一——Python开发环境篇
Pandas高级数据分析快速入门之二——基础篇
Pandas高级数据分析快速入门之三——数据挖掘与统计分析篇
Pandas高级数据分析快速入门之四——数据可视化篇
Pandas高级数据分析快速入门之五——机器学习特征工程篇
Pandas高级数据分析快速入门之六——机器学习预测分析篇

1. 关于Matlibplot

Matplotlib 是 Python 的绘图库。 它可与 NumPy 一起使用,提供了一种有效的 MatLab 开源替代方案。

import matplotlib.pyplot as plt
import numpy as np
from scipy import stats  # 科学计算包

def stats_linear_regression(df):
    user_df = df.loc[df['carduser_id']== 2085603 ].reset_index(drop=True)
       
    Days = user_df['days'].values
    Days = Days[1:]
    k = []
    for i in range(len(Days)):
        k.append(i)
    #Days = Days.reshape(-1,1)
    x = np.array(k)
    y = Days
    # 科学计算包中统计方法,用于计算散点回归线趋势的斜率、截距
    slope, intercept, r_value, p_value, std_err = stats.linregress(x, y) 
    print('slope is ' + str(slope))
    
    # 画图
    plt.rcParams['figure.figsize']= 10,5 #设置图例尺寸
    plt.rcParams['font.sans-serif']=['SimHei'] #设置为中文黑体,如果设置楷体则为 KaiTi
    plt.rcParams['axes.unicode_minus']=False

    plt.scatter(x, y, color='b',label='间隔时间')
    plt.plot(x, slope*x + intercept, color='r',label='趋势回归线')
    plt.legend()      #绘制图例,右上角标识图
    plt.show()        #显示图形
    # plt.savefig("temp.png")

数据及代码,接上文[1]

其中,绘图通用、基本部分为设置图片尺寸和中文兼容设置,详见代码中的注释。

提示:示例代码中plt.savefig(“temp.png”),很容易的把图像保存到文件中,如果直接生产文件时,可以不使用plt.show()函数(界面不显示)。

stats_linear_regression(trade_df)
slope is -0.11791958041958041

在这里插入图片描述

2. Pandas绘图

Pandas绘图是基于Matlibplot和Numpy,二次封装,以实现简化绘图工作。

2.1. 画直方图

plt.rcParams['figure.figsize']= 12,6 
plt.rcParams['font.sans-serif']=['SimHei'] #显示中文标签 KaiTi
plt.rcParams['axes.unicode_minus']=False

df=trade_df[['balance','recharge','volumn','amount']] # 交易数据来自上篇文章内容
df.hist()
plt.show()

在这里插入图片描述

2.2. 画密度图曲线图

接续上一锻炼“2.1”代码。

df.plot(kind='density',subplots=True,layout=(2,2),sharex=False,fontsize=8)
plt.show()

在这里插入图片描述

2.3. 画折线图

使用上篇文章[1]的月份交易汇聚数据,详见其代码顺序执行即可。

user_df = ms_df.loc[ms_df['carduser_id']==2085603].reset_index(drop=True)
# 月份转序列化
user_df[['年月']] = user_df['yearmonth'].apply(lambda x: str(x)[0:4] + '-' + str(x)[4:6])

df = user_df[['balance','recharge','amount','年月']]
df = df.set_index('年月')

df.plot()

注:代码中,额外增加把年月转换为字符串后,做为横坐标的序列,而不是原有数字,避免为直接数值大小的使用。

在这里插入图片描述

2.4. 画柱状图

user_df = ms_df.loc[ms_df['carduser_id']==2085603].reset_index(drop=True)
# 月份转序列化
user_df[['年月']] = user_df['yearmonth'].apply(lambda x: str(x)[0:4] + '-' + str(x)[4:6])

df = user_df[['balance','recharge','amount','年月']]
df = df.set_index('年月')

df.plot.bar()

在这里插入图片描述

2.5. 画饼状图

user_df = ms_df.loc[(ms_df['carduser_id']==2085603) & (ms_df['year']==2021)].reset_index(drop=True)
# 月份转序列化
user_df[['年月']] = user_df['yearmonth'].apply(lambda x: str(x)[0:4] + '-' + str(x)[4:6])

df = user_df[['balance','recharge','amount','年月']]
df = df.set_index('年月')
df.plot.pie(subplots=True,figsize=(10, 8),autopct='%.2f%%',radius = 1.2,startangle = 250,legend=False,colormap='viridis')

在这里插入图片描述

2.6. 画条形图

user_df = ms_df.loc[(ms_df['carduser_id']==2085603) & (ms_df['year']==2021)].reset_index(drop=True)
# 月份转序列化
user_df[['年月']] = user_df['yearmonth'].apply(lambda x: str(x)[0:4] + '-' + str(x)[4:6])

df = user_df[['balance','recharge','amount','年月']]
df = df.set_index('年月')
df.plot.barh()

在这里插入图片描述

3. 复杂图形

3.1. 热力图(皮尔逊相关)

import matplotlib.pyplot as plt

cols_name = ['carduser_id','yearmonth','sumamount','recharge','amount','goods','volumn','tradecount','balance','month','year']
cols_name.remove('carduser_id') #客户号不参与相关计算,没有意义
correlations = ms_df[cols_name].corr(method='pearson',min_periods=1)  #计算变量之间的相关系数矩阵
plt.rcParams['figure.figsize']= 12,10 
fig = plt.figure() #调用figure创建一个绘图对象
ax = fig.add_subplot(111)
cax = ax.matshow(correlations,cmap = 'viridis', vmin=-1, vmax=1)  #绘制热力图,从-1到1
fig.colorbar(cax)  #将matshow生成热力图设置为颜色渐变条
ticks = np.arange(0,len(correlations),1) #生成0-9,步长为1
ax.set_xticks(ticks)  #生成刻度
ax.set_yticks(ticks)
ax.set_xticklabels(cols_name) #生成x轴标签
ax.set_yticklabels(cols_name)
plt.show()

在这里插入图片描述

3.2. 雷达图

import numpy as np
import matplotlib.pyplot as plt
# 用于正常显示中文
plt.rcParams['font.sans-serif'] = 'SimHei'
#用于正常显示符号
plt.rcParams['axes.unicode_minus'] = False

# 使用ggplot的绘图风格,这个类似于美化了,可以通过plt.style.available查看可选值,你会发现其它的风格真的丑。。。
plt.style.use('ggplot')

# 构造数据
user_df = ms_df.loc[(ms_df['carduser_id']==1313943) & (ms_df['yearmonth']==201909)].reset_index(drop=True)
# 转换数据在雷达范围 0,5
df = user_df[['balance','recharge','amount','volumn','goods']].apply(lambda x:x/15000)
df = df.rename(columns={'balance':'余额','recharge':'充值','amount':'金额','volumn':'加油量','goods':'非油消费'})
print(df)
feature = df.columns.tolist()
print(feature)
values = df.values.tolist()[0]
print(values)
# 设置每个数据点的显示位置,在雷达图上用角度表示
angles=np.linspace(0, 2*np.pi,len(values), endpoint=False)

# 拼接数据首尾,使图形中线条封闭
values=np.concatenate((values,[values[0]]))
print(values)
angles=np.concatenate((angles,[angles[0]]))
print(angles)

# 绘图
fig=plt.figure()
# 设置为极坐标格式
ax = fig.add_subplot(111, polar=True)
# 绘制折线图
ax.plot(angles, values, 'o-', linewidth=2)
# 填充颜色
ax.fill(angles, values, alpha=0.25)

# 设置图标上的角度划分刻度,为每个数据点处添加标签
ax.set_thetagrids(angles * 180/np.pi, feature)

# 设置雷达图的范围
ax.set_ylim(0,5)
# 添加标题
plt.title('客户月消费情况')
# 添加网格线
ax.grid(True)

plt.show()

源代码参考[3]
在这里插入图片描述
参考:

[1]. 肖永威 . Pandas高级数据分析快速入门之三——数据挖掘与统计分析篇 ,CSDN博客 ,2021-08
[2]. hgz_dm .利用matlibplot绘制雷达图, 博客园 ,2019-05
[3]. 肖永威 . Python Matplotlib绘制渐变色柱状图(bar)并加边框和配置渐变颜色条(colorbar) ,CSDN博客 ,2020-09

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
### 回答1: Pandas是一个Python库,用于数据处理和分析。在数据分析中,预处理是非常重要的一步,因为它可以帮助我们清洗和转换数据,使其更适合进行分析。Pandas提供了一些强大的预处理功能,包括数据清洗、数据转换、数据重塑和数据合并等。在使用Pandas进行数据分析时,预处理是必不可少的一步。 ### 回答2: 在数据分析中,数据的预处理是一个必要的过程。它的主要目的是清洗数据,准备数据,以便后续分析。在Python中,pandas是一种广泛使用的数据处理库。pandas可以通过其高效的数据结构和操作方法来清洗和处理数据。在本文中,将介绍pandas预处理的一些常见技术。 一、读取数据 在pandas中,使用read_csv()函数读取CSV格式的数据文件,read_excel()函数读取Excel格式的数据文件。它们都有很多选项,可以根据具体文件的格式进行设置。 二、查看数据 在pandas中,使用以下函数来查看数据: 1. head() - 显示数据框的前几行; 2. tail() - 显示数据框的后几行; 3. columns - 显示数据框的列名; 4. shape - 显示数据框的行列数; 5. info() - 显示数据框的基本信息,包括每列的名称、非空值数量和数据类型。 三、数据清洗 在数据清洗中,有以下一些常见的技术: 1. 删除重复行:使用drop_duplicates()函数; 2. 替换空值:使用fillna()函数; 3. 删除空值:使用dropna()函数; 4. 更改数据类型:使用astype()函数。 四、数据准备 在数据准备中,有以下一些常见的技术: 1. 数据合并:使用merge()函数; 2. 数据筛选:使用loc()函数或者iloc()函数; 3. 数据分组:使用groupby()函数; 4. 数据排序:使用sort_values()函数。 五、数据分析数据分析中,有以下一些常见的技术: 1. 数据聚合:使用agg()函数; 2. 统计描述:使用describe()函数; 3. 数据可视化:使用matplotlib或者seaborn库。 综上所述,pandas预处理是数据分析中必不可少的一步。通过使用pandas提供的函数和方法,可以方便地清理和处理数据,使其更容易被分析。 ### 回答3: PandasPython中最强大的数据处理库之一,它提供了DataFrame和Series这两种数据结构,可以快速便捷地处理数据。在数据分析过程中,我们往往需要先对数据进行预处理,以便后续的分析。Pandas提供了一系列的方法和函数,可以帮助我们进行数据的预处理。 首先,在进行数据分析之前,我们需要了解自己所面对的数据类型和数据结构。Pandas中的DataFrame结构就是类似于表格的结构,每一行代表一个样本,每一列代表一个属性。Series则是一维的数组结构。通过pandas.read_csv(),我们可以读取CSV格式的数据,并转化为DataFrame结构。 接下来,我们要对数据进行一些基本的处理,例如数据清洗、数据去重、缺失值处理、异常值处理等。在数据清洗过程中,我们往往需要对数据进行一些特殊的处理,例如字符串的分割、合并、替换等操作,Pandas提供了一系列能够对文本进行操作的函数。在数据去重方面,我们可以使用drop_duplicates()函数,它可以去除DataFrame中的重复记录。在处理缺失值时,Pandas提供了一系列的函数,如fillna()函数、dropna()函数,可以方便地将NaN值变为其他有意义的值,或者删除缺失值的行或列。在异常值处理方面,我们可以使用isoutlier()函数来找到数据中的异常值,并进行处理。 在数据预处理完成后,我们可以对数据进行一些统计分析,例如计算小计、计算总计、分位数、极差、方差、标准差等统计指标。我们可以使用describe()函数来获得数据的统计描述,还可以使用groupby()函数来对数据分组,使用agg()函数对每组进行计算统计指标。此外,我们还可以对数据进行排序、丢弃、合并等操作。 总之,Pandas是一个非常强大的Python库,可以轻松处理数据预处理和数据处理方面的任务。Pandas作为数据分析和数据处理的基础库,使用熟练后可以在数据分析中发挥更大的作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

肖永威

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值