pandas数据处理 + matplotlib可视化(电影票房分析)

1、首先导入包

# 导入库
import numpy as np
import matplotlib.pyplot as plt  # 绘图的库
import pandas as pd

2、读取文件

# 读取、打开文件
df = pd.read_csv(open('E:\电影票房.csv',encoding='ANSI'))
df.head(5)

我们的文件含有中文名,加上open( )好一点

查看数据如下
在这里插入图片描述

3、使用iloc( )切片数据

df = df.iloc[:,[3,5]]  # 切出行的全部、列的第3第5列
df.head(5)

这里顺便可以讲一下 iloc( ) 和 loc( ) 的区别,iloc 是使用索引取数据,loc 使用列名取数据;

上面的写法用 loc( ) 可以写成:

data.loc[:, ['类型', '全球票房']]  # 等同于data.iloc[:, [3, 5]]

在这里插入图片描述

4、分割、聚合数据

从第三题的 “类型” 列来看,有两种类型合在一起了(有的一种、有的两种),有两种的由 “竖杠” 分隔;我们要取出两种类型,形成两个列 “类型1” 和 “类型2” (也就是说这里的一个电影有两种类型)

首先定义一个函数,传入 item ,返回的内容是跟据斜杠分隔的 索引 为0的数据,这个是取第一个类型

def func1(item):
    return item.split('/')[0]

再定义一个函数,取第二个类型;有可能 “类型” 这一列只有一个类型,所以用 if 做个判断,如果有两个类型,就取索引为 1 的那个类型,没有第二个类型就用 0 替代 (后面要把 “类型2” 是 0 的行删除)

def func2(item):
    if '/' in item:
        return item.split('/')[1]
    else:
        return 0

接下来调用函数,就是让 “这个” 数据通过筛选

df['类型1'] = df['类型'].map(func1)
df['类型2'] = df['类型'].map(func2)

我们看到的数据后面的 .map( func1 )其实是进行匹配、换算,如果一个数据后面写 .map(float) 就是把这个数据类型转换成单精度类型

接着用 iloc( ) 继续取需要的数据

data_1 = df.iloc[:,[2,1]]
data_2 = df.iloc[:,[3,1]]
data_2 = df[data_2['类型2'] != 0]  # 剔除“类型2”中为0的项
data_2.head(5)

然后 data_2的数据就如下所示

在这里插入图片描述

5、去除 “全球票房” 后面的单位 “ $ ”

在第四题后面我们可以看到 “全球票房” 后面有个单位

这个有两种方法可以做

#  去除 ‘全球票房’ 后面的 ‘ $’

data_2['全球票房'] = data_2['全球票房'].str[:-1]
data_2

在这里插入图片描述
这里的,str里取的 “-1” 和冒号的意思就是取 “从开头到最后一个(不包含最后一个)”
也可以使用 .replace( “原字符”, “新字符”) 这种方法替换,新字符的地方不用写,直接冒号得了

6、数据单位的转换

跟据第五题后面的图片可以看到,“全球票房” 的数值太大,我们可以把 “元” 变成 “亿元”,就是除以相应的数

# data_2['全球票房'] = data_2['全球票房'].astype('int64')

def to_million(x):
    dollar = round(float(x)/100000000,4)
    return dollar
data_2['票房(亿元)'] = data_2['全球票房'].map(to_million)
data_2.head()

方法同样是自定义一个函数:
这里的 round( ) 就是用于保留多少位小数的, round(data, 2):就是保留两位小数,里面的float(x)就是强制转换 x 的数据类型为单精度类型, 4 就是保留 4 位小数

在这里插入图片描述
可以看见,换完单位我们的数值小很多,方便后面的可视化操作

7、跟据类型把票房分组求和

# 根据类型分组求和

df_counts = data_2[['类型1','票房(亿元)']].groupby('类型1').sum()
df_counts

将数据里面的 “ 类型1 ” 和 “ 票房(亿元)”两个数据单独拿出来
再计算各个类型的总票房(求和),我们把类型单独拿出来分成 类型1 和 类型2 之后还有重复的(这里的重复指的是类型重复,我们要计算这个榜单各个类型的电影有多少票房),现在把他们加起来

在这里插入图片描述

8、数据可视化操作

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.dates

然后准备数据(同时,把数据转化为列表),可视化只要列表数据

y = df_counts.index.tolist()
x = df_counts['票房(亿元)'].tolist()
# 设置画布
fig, ax=plt.subplots(figsize=(8,8))
# 设置标题
plt.title("全球票房")
# 画图(圆形)
plt.pie(x = x,labels = y,autopct='%.0f%%')  # autopct='%.0f%%'是让饼图显示
# 设置图例
plt.legend(ncol=6,loc='upper right')  # loc 这里这个用于表示图例显示的位置

# 让饼图变圆
plt.axis('equal')

plt.show()
  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一些Python库和步骤,可以用于电影票房据的分析可视化。 ### 1. 据获取与处理 可以通过爬取电影票房据的网站(如猫眼电影、豆瓣电影等)来获取据。也可以从公开的据集获取据(如Kaggle上的电影据集)。 获取到据后,需要进行据清洗和处理,如去除重复据、缺失值处理等。可以使用Pandas库进行数据处理和清洗工作。 ```python import pandas as pd # 读取CSV据文件 data = pd.read_csv('movie_data.csv') # 去除重复data.drop_duplicates(inplace=True) # 处理缺失值 data.fillna(0, inplace=True) ``` ### 2. 数据分析 进行数据分析前,需要先了解据的基本情况和特征。可以使用Pandas库提供的一些基本统计函,如describe()、mean()、median()等来获取据的基本信息。 ```python # 查看据基本信息 print(data.info()) # 查看据描述性统计信息 print(data.describe()) # 查看据前5行 print(data.head()) ``` 在对据进行分析时,可以根据问题需求,选择合适的统计方法和可视化方式。以下是一些常用的统计方法和可视化工具: - 统计方法:计、求和、平均、、方差、协方差、相关系等。 - 可视化工具:Matplotlib、Seaborn、Plotly等。 ### 3. 可视化 使用Matplotlib库进行可视化,可以制作直方图、散点图、折线图、饼图等。 ```python import matplotlib.pyplot as plt # 绘制票房据直方图 plt.hist(data['box_office'], bins=20) plt.title('Box Office') plt.xlabel('Box Office (Million)') plt.ylabel('Frequency') plt.show() # 绘制票房与评分散点图 plt.scatter(data['rating'], data['box_office']) plt.title('Box Office vs Rating') plt.xlabel('Rating') plt.ylabel('Box Office (Million)') plt.show() # 绘制不同年份电影量折线图 year_count = data.groupby('year')['title'].count() plt.plot(year_count.index, year_count.values) plt.title('Movie Count by Year') plt.xlabel('Year') plt.ylabel('Movie Count') plt.show() ``` 使用Seaborn库进行可视化,可以制作热力图、箱线图、条形图、密度图等。 ```python import seaborn as sns # 绘制票房与评分箱线图 sns.boxplot(x='rating', y='box_office', data=data) plt.title('Box Office vs Rating') plt.xlabel('Rating') plt.ylabel('Box Office (Million)') plt.show() # 绘制不同地区电影量条形图 region_count = data['region'].value_counts() sns.barplot(x=region_count.index, y=region_count.values) plt.title('Movie Count by Region') plt.xlabel('Region') plt.ylabel('Movie Count') plt.show() # 绘制票房密度图 sns.kdeplot(data['box_office']) plt.title('Box Office Density') plt.xlabel('Box Office (Million)') plt.show() ``` 使用Plotly库进行可视化,可以制作交互式图表,如散点图、热力图、地图等。 ```python import plotly.graph_objs as go import plotly.offline as pyo # 绘制票房与评分散点图(交互式) trace = go.Scatter(x=data['rating'], y=data['box_office'], mode='markers') layout = go.Layout(title='Box Office vs Rating', xaxis={'title': 'Rating'}, yaxis={'title': 'Box Office (Million)'}) fig = go.Figure(data=[trace], layout=layout) pyo.plot(fig) # 绘制不同地区电影量地图(交互式) region_count = data['region'].value_counts() data_map = [go.Choropleth( locationmode='country names', locations=region_count.index, z=region_count.values)] layout_map = go.Layout(title='Movie Count by Region') fig_map = go.Figure(data=data_map, layout=layout_map) pyo.plot(fig_map) ``` 以上是一些基本的数据分析可视化方法,可以根据具体需要进行更加详细的分析可视化

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值