pandas读取csv文件数据并对指定字段分类使用matplotlib在一张图里画四张折线图子图

csv数据如下:

代码如下:

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = 'simhei'
plt.rcParams['axes.unicode_minus']=False

data = pd.read_csv('student.csv')
# 分组函数,按照行索引进行分组,把省份相等的字段分组在一起
# obj.groupby([‘key1’,’key1’]),把key1和key2相等的字段分组在一起
data = data.groupby('省份')

hnsq = []
hnrs = []

# 必须遍历拿数据,且里面只有两组数据,分组的索引和所有的数据
for i,info in data:
    if i == '湖北':
        sq = info['市区']
        rs = info['人数']
        plt.subplot(2,2,1)
        plt.plot(np.arange(len(sq)),rs,'-*')
        plt.xticks(np.arange(len(sq)),sq)
    elif i == '湖南':
        sq = info['市区']
        rs = info['人数']
        plt.subplot(2,2,2)
        plt.plot(np.arange(len(sq)),rs,'-*')
        plt.xticks(np.arange(len(sq)),sq)
    elif i == '西藏':
        sq = info['市区']
        rs = info['人数']
        plt.subplot(2,2,3)
        plt.plot(np.arange(len(sq)),rs,'-*')
        plt.xticks(np.arange(len(sq)),sq)
    elif i == '贵州':
        sq = info['市区']
        rs = info['人数']
        plt.subplot(2,2,4)
        plt.plot(np.arange(len(sq)),rs,'-*')
        plt.xticks(np.arange(len(sq)),sq)
    else:
        pass
plt.tight_layout()
plt.show()

效果图如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值