条形图(bar chart)也称为柱状图,是一种以长方形的长度为变量的统计图表,长方形的长度与它所对应的数值呈一定比例。
导入绘图数据
竖放条形图
2.1 竖放条形图绘图原理
2.2 绘制竖放条形图
2.3 优化绘制竖放条形图
横放条形图
3.1 横放条形图绘图原理
3.2 绘制横放条形图
并列条形图
叠加条形图
拼接条形图
多重显示条形图

import osimport pandas as pdos.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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




