python 宝可梦_Python之宝可梦数据分析实战

宝可梦数据分析

数据集下载:

# 数据集下载

!wget -O pokemon_data.csvhttps://pai-public-data.oss-cn-beijing.aliyuncs.com/pokemon/pokemon.csv

利用Pandas, Seaborn, Matplotlib, 并且读取数据:

import pandas as pd

import seaborn as sns

import matplotlib.pyplot as plt

df = pd.read_csv("./pokemon_data.csv")

通过如下代码来观察每个特征的缺失情况:

# 计算出每个特征有多少百分比是缺失的

percent_missing = df.isnull().sum() * 100 / len(df)

missing_value_df = pd.DataFrame({

'column_name': df.columns,

'percent_missing': percent_missing

})

# 查看Top10缺失的

missing_value_df.sort_values(by='percent_missing', ascending=False).head(10)

用pandas自带的画图的功能来绘制一个柱状图:

# 查看各代口袋妖怪的数量

df['generation'].value_counts().plot.bar()

再来看不同的主属性的分布:

# 查看每个系口袋妖怪的数量

df['type1'].value_counts().sort_values(ascending=True).plot.barh()

ticklabels=corr.columns.values)

通过以下的代码生成相关性图

#相关性热力图分析

plt.subplots(figsize=(20,15))

ax = plt.axes()

ax.set_title("Correlation Heatmap")

corr = df.corr()

sns.heatmap(corr,

xticklabels=corr.columns.values,

yticklabels=corr.columns.values)

接下来我们从宝可梦在实战中的角度来分析这组数据。这里我们只关注六个基础值:血量,攻击力,防御力,特攻,特防,速度。因为只有这六个基础值决定了一只宝可梦的战斗力在不考虑派系克制的情况下。

interested = ['hp','attack','defense','sp_attack','sp_defense','speed']

sns.pairplot(df[interested])

相关性热力图:

# 通过相关性分析heatmap分析五个基础属性

plt.subplots(figsize=(10,8))

ax = plt.axes()

ax.set_title("Correlation Heatmap")

corr = df[interested].corr()

sns.heatmap(corr,

xticklabels=corr.columns.values,

yticklabels=corr.columns.values,

annot=True, fmt="f",cmap="YlGnBu")

特征类型转化:

for c in interested:

df[c] = df[c].astype(float)

df = df.assign(total_stats = df[interested].sum(axis=1))

做个柱状图可视化来看看种族值的分布是什么样的:

# 种族值分布

total_stats = df.total_stats

plt.hist(total_stats,bins=35)

plt.xlabel('total_stats')

plt.ylabel('Frequency')

data=df, palette="muted")

还可以根据不同的属性来看:

# 不同属性的种族值分布

plt.subplots(figsize=(20,12))

ax = sns.violinplot(x="type1", y="total_stats",

data=df, palette="muted")

最后我们就可以通过简单的过滤和排序来找到我们应该去捕捉的宝可梦了

df[(df.total_stats >= 570) & (df.is_legendary == 0)]['name'].head(10)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值