hands-on-data-analysis 第二单元 第四节数据可视化

举报
陈沧夜 发表于 2022/06/20 19:20:22 2022/06/20
【摘要】 # hands-on-data-analysis 第二单元 第四节数据可视化## 1.简单绘图### 1.1.导入库```python#inline表示将图表嵌入到Notebook中%matplotlib inlineimport numpy as npimport pandas as pdimport matplotlib.pyplot as plt```### 1.2.基本的绘图示例``...

# hands-on-data-analysis 第二单元 第四节数据可视化

## 1.简单绘图

### 1.1.导入库

```python
#inline表示将图表嵌入到Notebook中
%matplotlib inline
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
```

### 1.2.基本的绘图示例

```python
import numpy as np
data  = np.arange(10)
data
plt.plot(data)
```

### 1.3.子图示例

```python
fig = plt.figure()
ax1 = fig.add_subplot(2,2,1)
ax2 = fig.add_subplot(2,2,2)
ax3 = fig.add_subplot(2,2,3)
ax4 = fig.add_subplot(2,2,4)
```


### 1.4.子图绘图示例

```python
fig = plt.figure()
ax1 = fig.add_subplot(2,2,1)
ax2 = fig.add_subplot(2,2,2)
ax3 = fig.add_subplot(2,2,3)
#k--是绘制黑色分段线的选项
plt.plot(np.random.randn(50).cumsum(),'k--')
_ = ax1.hist(np.random.randn(100),bins=20,color='k',alpha=0.3)
ax2.scatter(np.arange(30),np.arange(30)+3*np.random.randn(30))
```

### 1.5. pyplot.subplots选项

| 参数       | 描述                                                         |
| ---------- | ------------------------------------------------------------ |
| nrows      | 子图的行数                                                   |
| ncols      | 子图的列数                                                   |
| sharex     | 所有子图使用相同的x轴刻度(调整xlim会影响所有子图)            |
| sharey     | 所有子图使用相同的y轴刻度(调整ylim会影响所有子图)            |
| subplot_kw | 传入add_subplot的关键字参数字典,用于生成子图                |
| **fig_kw   | 在生成图片时使用的额外关键字参数,例如plt.subplot(2,2,figsize(8,6)) |

## 2.可视化展示泰坦尼克号数据集中男女中生存人数分布情况

```python
sex = text.groupby('Sex')['Survived'].sum()
sex.plot.bar()
plt.title('survived_count')
plt.show()
```


## 3.可视化展示泰坦尼克号数据集中男女中生存人与死亡人数的比例图

```python
text.groupby(['Sex','Survived'])['Survived'].count().unstack().plot(kind='bar',stacked='True')
plt.title('survived_count')
plt.ylabel('count')
```

## 4.可视化展示泰坦尼克号数据集中不同票价的人生存和死亡人数分布情况。

```python
# 计算不同票价中生存与死亡人数 1表示生存,0表示死亡
fare_sur = text.groupby(['Fare'])['Survived'].value_counts().sort_values(ascending=False)
fare_sur
```

```python
fig = plt.figure(figsize=(20, 18))
fare_sur.plot(grid=True)
plt.legend()
plt.show()
```


## 5.可视化展示泰坦尼克号数据集中不同仓位等级的人生存和死亡人员的分布情况

```python
# 1表示生存,0表示死亡
pclass_sur = text.groupby(['Pclass'])['Survived'].value_counts()
pclass_sur
```

```python
import seaborn as sns
sns.countplot(x="Pclass", hue="Survived", data=text)
```

## 6.可视化展示泰坦尼克号数据集中不同年龄的人生存与死亡人数分布情况

```python
facet = sns.FacetGrid(text, hue="Survived",aspect=3)
facet.map(sns.kdeplot,'Age',shade= True)
facet.set(xlim=(0, text['Age'].max()))
facet.add_legend()
```

## 7.可视化展示泰坦尼克号数据集中不同仓位等级的人年龄分布情况。

```python
text.Age[text.Pclass == 1].plot(kind='kde')
text.Age[text.Pclass == 2].plot(kind='kde')
text.Age[text.Pclass == 3].plot(kind='kde')
plt.xlabel("age")
plt.legend((1,2,3),loc="best")
```

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。