条形图(bar chart)也称为柱状图,是一种以长方形的长度为变量的统计图表,长方形的长度与它所对应的数值呈一定比例。
导入绘图数据
竖放条形图
2.1 竖放条形图绘图原理
2.2 绘制竖放条形图
2.3 优化绘制竖放条形图
横放条形图
3.1 横放条形图绘图原理
3.2 绘制横放条形图
并列条形图
叠加条形图
拼接条形图
多重显示条形图
import os
import pandas as pd
os.chdir(r'F:\公众号\6.学习python') #设置成存放数据文件夹路径
date = pd.read_csv("股票数据.csv", encoding = 'GBK') #读取数据
1 竖放条形图绘图原理
bar(x, height, [width], [bottom], **kwargs)
import matplotlib.pyplot as plt #导入库
date = date.set_index('日期') #把日期列设为索引
date.index = pd.to_datetime(date.index) #把索引转为时间格式
plt.bar(date.index, date['收盘价']) #以日期为横轴,收盘价为纵轴绘制条形图
result = date[['收盘价']].groupby(date.index.year).mean() #计算每年收盘价均值
plt.rcParams['font.sans-serif'] = ['SimHei'] # 解决中文显示问题
plt.rcParams['axes.unicode_minus'] = False # 解决中文显示问题
plt.bar(result.index, result['收盘价'], 0.6, label='close', color='#87CEFA')
plt.legend() #显示图例
plt.xlabel('时间') #x轴标签
plt.ylabel('收盘价') #y轴标签
plt.title('股票收盘价') #标题
barh(y, width, [height], **kwargs)
result = date[['收盘价']].groupby(date.index.year).mean() #计算每年收盘价均值
plt.barh(result.index, result['收盘价']) #以时间为纵轴,收盘价为高度绘制横向条形图
result = date.groupby(date.index.year).agg(high=('最高价','mean'), low=('最低价','mean')) #分别计算每年股票最高价、最低价均值
plt.bar(result.index, result['high'], width=0.2, color='r', label='high') #绘制每年股票最高价均值的条形图,颜色设置为红色
plt.bar(result.index+0.2, result['low'], width=0.2, color ='b', label='low') #绘制每年股票最低价均值的条形图,颜色设置为蓝色
plt.xticks(result.index+0.2, result.index) # 让横坐标轴刻度显示时间,result.index+0.2为横坐标轴刻度的位置
plt.ylim(5, 35) #设置y轴的显示范围
plt.title('股票最高价最低价') #设置标题
plt.legend() #显示图例
result = date.groupby(date.index.year).agg(high=('最高价','mean'), low=('最低价','mean')) #分别计算每年股票最高价、最低价均值
plt.bar(result.index, result['high'], width=0.2, color='r', alpha=0.5, label='high') #绘制股票最高价条形图,颜色为红色
plt.bar(result.index, result['low'], width=0.2, color='b', alpha=0.5, label='low') #绘制股票最低价条形图,颜色为蓝色
plt.title('叠加股票最高价最低价条形图') #设置标题
plt.legend() #显示图例
result = date.groupby(date.index.year).agg(high=('最高价','mean'), low=('最低价','mean')) #分别计算每年股票最高价、最低价均值
plt.bar(result.index, result['high'], width=0.2, color='r', label='high') #绘制股票最高价条形图
plt.bar(result.index, result['low'], bottom=result['high'], width=0.2, color='b', label='low') #以股票最高价为起点绘制股票最低价条形图
plt.title('股票最高价最低价拼接条形图') #设置标题
plt.legend() #显示图例
import matplotlib.cm as cm #导入库
result = date.groupby(date.index.year).agg(avgl=('收盘价', 'mean'), avg2=('换手率', 'mean')) #按年统计股票收盘价和换手率的均值
plt.bar(result.index, result['avgl'], color=cm.ScalarMappable().to_rgba(result['avg2'])) #以收盘价均值为高度,换手率均值为颜色绘制条形图
sm = plt.cm.ScalarMappable(norm=plt.Normalize(vmin=result['avg2'].min(), vmax=result['avg2'].max()))
plt.colorbar(sm) #根据换手率均值的大小显示颜色
plt.title('用收盘价和换手率绘制多重显示条形图') #设置标题
plt.show()
至此,在Python中绘制条形图已全部讲解完毕,感兴趣的同学可以自己实现一遍。
扫一扫关注我
19967879837
投稿微信号、手机号
文章转载自阿黎逸阳的代码,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。