数据分析基础之《pandas(8)—综合案例》

一、需求

1、现在我们有一组从2006年到2016年1000部最流行的电影数据

数据来源:https://www.kaggle.com/damianpanek/sunday-eda/data

2、问题1

想知道这些电影数据中评分的平均分,导演的人数等信息,我们应该怎么获取?

3、问题2

对于这一组电影数据,如果我们想看Rating、Runtime (Minutes)的分布情况,应该如何呈现数据?

4、问题3

对于这一组电影数据,如果我们希望统计电影分类genre的情况,应该如何处理数据?

二、实现

1、问题1

python 复制代码
# 综合案例
movie= pd.read_csv("./IMDB-Movie-Data.csv")

movie

# 想知道这些电影数据中评分的平均分,导演的人数等信息,我们应该怎么获取?
# 评分的平均分
movie["Rating"].mean()

# 导演的人数信息
np.unique(movie["Director"]).size

2、问题2

python 复制代码
# 对于这一组电影数据,如果我们想看Rating、Runtime (Minutes)的分布情况,应该如何呈现数据?
import matplotlib.pyplot as plt

# 创建画布
plt.figure(figsize=(20,8), dpi=100)

# 绘制直方图
plt.hist(movie["Rating"], 20)

# 修改刻度
max_ = movie["Rating"].max()
min_ = movie["Rating"].min()
plt.xticks(np.linspace(max_, min_, num=21))

# 添加网格
plt.grid(linestyle="--", alpha=0.8)

# 显示图像
plt.show()

3、问题3

思路分析:

(1)创建一个temp_df,全为0的dataframe,列索引值为电影的分类

(2)遍历每一部电影,temp_df中把分类出现的列的值置为1

(3)求和

python 复制代码
# 对于这一组电影数据,如果我们希望统计电影分类genre的情况,应该如何处理数据?
# 先统计电影类别都有哪些
movie_genre = [i.split(",") for i in movie["Genre"]]

movie_genre

# 拆分
movie_class = np.unique([j for i in movie_genre for j in i])

movie_class

# 统计每个电影有几个类别
count = pd.DataFrame(np.zeros(shape=[1000, 20], dtype="int32"), columns=movie_class)

count

for i in range(1000):
    count.loc[i, movie_genre[i]] = 1

count

count.sum(axis=0).sort_values(ascending=False).plot(kind="bar", figsize=(20, 8), fontsize=20, colormap="cool")

三、小结

pandas高级数据处理

缺失值处理

缺失值是NaN类型

判断是否存在np.nan缺失值

pd.isnull(df).any()

pd.notnull(df).all()

两种思路

删除df.dropna()

替换sr.fillna(value, replace=)

缺失值是其他默认符号

替换df.replace(to_replace="?", value=np.nan)

按照处理nan的步骤

数据离散化

分组

自动分组pd.qcut(data, bins)

自定义分组pd.cut(data, bins)

转换

pd.get_dummies(分好组的数据, prefix=)

数据合并

按方向合并

pd.concat((a,b), axis=)

按索引合并

pd.merge(left, right, how="inner", on=)

交叉表与透视表

pd.crosstab(value1, value2)

df.pivot_table([字段], index=)

分组与聚合

用dataframe.groupby(by=).聚合函数()

用sr.groupby(sr).聚合函数()

相关推荐
qq_436962182 小时前
奥威BI:打破数据分析的桎梏,让决策更自由
人工智能·数据挖掘·数据分析
B站计算机毕业设计之家3 小时前
大数据python招聘数据分析预测系统 招聘数据平台 +爬虫+可视化 +django框架+vue框架 大数据技术✅
大数据·爬虫·python·机器学习·数据挖掘·数据分析
Tiandaren15 小时前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
人大博士的交易之路21 小时前
龙虎榜——20251106
大数据·数学建模·数据分析·缠论·缠中说禅·龙虎榜
YangYang9YangYan21 小时前
中专服装设计专业职业发展指南
大数据·人工智能·数据分析
ClouGence1 天前
百草味数据架构升级实践:打造 Always Ready 的企业级数据平台
大数据·数据库·数据分析
口_天_光健1 天前
制造企业的数据目录编写
大数据·数据库·数据仓库·数据分析
城数派1 天前
1951-2100年全球复合极端气候事件数据集
人工智能·数据分析
汤姆yu1 天前
基于大数据的短视频流量数据分析与可视化
大数据·数据挖掘·数据分析
Tiger Z1 天前
《R for Data Science (2e)》免费中文翻译 (第12章) --- Logical vectors(1)
数据分析·r语言·数据科学·免费书籍