好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

python绘制柱形图的方法

本文实例为大家分享了python绘制柱形图的具体代码,供大家参考,具体内容如下

#柱形图
import pandas
import numpy
import matplotlib?
from matplotlib import pyplot as plt
#导入数据
data_columns=pandas.read_csv('D://Python projects//reference data//6.4//data.csv')
#定义中文格式
font={'family':'MicroSoft Yahei',
? ? ? 'weight':'bold',
? ? ? 'size':12}
matplotlib.rc('font',**font)
#使用手机品牌作为分组列,月消费作为统计列
result_columns=data_columns.groupby(
? ? ? ? by=['手机品牌'],
? ? ? ? as_index=False)['月消费(元)'
? ? ? ? ? ? ? ? ? ? ? ].agg({'月总消费':numpy.sum
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? })
#生成一个间隔为1的序列
index=numpy.arange(result_columns.月总消费.size)
#绘制纵向柱形图
plt.bar(index,result_columns['月总消费'])
#%matplotlib qt
plt.show()
#配置颜色
maincolor=(42/256,87/256,141/256,1)
plt.bar(index,
? ? ? ? result_columns['月总消费'])
plt.show()
#配置X轴标签
plt.bar(index,
? ? ? ? result_columns['月总消费'])
plt.xticks(index,result_columns.手机品牌)
plt.show()
#对数据进行降序排序后展示
result_asd=result_columns.sort_values(
? ? ? ? by='月总消费',
? ? ? ? ascending=False)
plt.bar(index,
? ? ? ? result_asd.月总消费,
? ? ? ? color=maincolor)
plt.xticks(index,result_asd.手机品牌)
plt.show()

结果为:

#横向柱形图
result_asd=result_columns.sort_values(
? ? ? ? by='月总消费',
? ? ? ? ascending=False)
plt.barh(index,
? ? ? ? result_asd.月总消费,
? ? ? ? color=maincolor)
plt.yticks(index,result_asd.手机品牌)
plt.show()

结果为:

#计算出交叉表的数据
result=data_columns.pivot_table(
? ? ? ? values='月消费(元)',
? ? ? ? index='手机品牌',
? ? ? ? columns='通信品牌',
? ? ? ? aggfunc=numpy.sum)

结果为:

#定义三个颜色
index=numpy.arange(len(result))
mincolor=(42/256,87/256,141/256,1/3)
midcolor=(42/256,87/256,141/256,2/3)
maxcolor=(42/256,87/256,141/256,1)
#建立簇状柱形图
plt.bar(
? ? ? ? index,
? ? ? ? result['全球通'],
? ? ? ? color=mincolor,
? ? ? ? width=1/4)
plt.bar(
? ? ? ? index+1/4,
? ? ? ? result['动感地带'],
? ? ? ? color=midcolor,
? ? ? ? width=1/4)
plt.bar(
? ? ? ? index+1/2,
? ? ? ? result['神州行'],
? ? ? ? color=maxcolor,
? ? ? ? width=1/4)
plt.xticks(index+1/3,result.index)
#添加图例
plt.legend(['全球通','动感地带','神州行'])
plt.show()

结果为:

#重新排序进行绘制
result=result.sort_values(
? ? ? ? by='神州行',
? ? ? ? ascending=False)
plt.bar(
? ? ? ? index,
? ? ? ? result['全球通'],
? ? ? ? color=mincolor,
? ? ? ? width=1/4)
plt.bar(
? ? ? ? index+1/4,
? ? ? ? result['动感地带'],
? ? ? ? color=midcolor,
? ? ? ? width=1/4)
plt.bar(
? ? ? ? index+1/2,
? ? ? ? result['神州行'],
? ? ? ? color=maxcolor,
? ? ? ? width=1/4)
plt.xticks(index+1/3,result.index)
plt.legend(['全球通','动感地带','神州行'])
plt.show()

结果为:

#绘制堆叠柱形图
result=result.sort_values(
? ? ? ? by='神州行',
? ? ? ? ascending=False)
plt.bar(
? ? ? ? index,
? ? ? ? result['全球通'],
? ? ? ? color=maxcolor)
plt.bar(
? ? ? ? index,
? ? ? ? result['动感地带'],
? ? ? ? bottom=result['全球通'],
? ? ? ? color=midcolor)
plt.bar(
? ? ? ? index,
? ? ? ? result['神州行'],
? ? ? ? bottom=result['全球通']+result['动感地带'],
? ? ? ? color=mincolor)
plt.xticks(index,result.index)
plt.legend(['全球通','动感地带','神州行'])
plt.show()

结果为:

#绘制双向柱形图
plt.barh(
? ? ? ? index,
? ? ? ? result['神州行'],
? ? ? ? color=midcolor)
plt.barh(
? ? ? ? index,
? ? ? ? -result['动感地带'],
? ? ? ? color=maxcolor)
plt.yticks(index,
? ? ? ? ? ?result.index)
plt.legend(['动感地带','神州行'])
plt.show()

结果为:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

查看更多关于python绘制柱形图的方法的详细内容...

  阅读:54次