简体   繁体   English

如何在pandas中的数据帧中绘制直方图

[英]how to plot histograms from dataframes in pandas

I have a simple dataframe in pandas that has two numeric columns. 我在pandas中有一个简单的数据框,它有两个数字列。 I want to make a histogram out of the columns using matplotlib through pandas. 我想通过pandas使用matplotlib从列中制作直方图。 The example below does not work: 以下示例不起作用:

In [6]: pandas.__version__
Out[6]: '0.14.1'

In [7]: df
Out[7]: 
   a   b
0  1  20
1  2  40
2  3  30
3  4  30
4  4   3
5  3   5

In [8]: df.plot(kind="hist")
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-8-4f53176a4683> in <module>()
----> 1 df.plot(kind="hist")

/software/lib/python2.7/site-packages/pandas/tools/plotting.pyc in plot_frame(frame, x, y, subplots, sharex, sharey, use_index, figsize, grid, legend, rot, ax, style, title, xlim, ylim, logx, logy, xticks, yticks, kind, sort_columns, fontsize, secondary_y, **kwds)
   2095         klass = _plot_klass[kind]
   2096     else:
-> 2097         raise ValueError('Invalid chart type given %s' % kind)
   2098 
   2099     if kind in _dataframe_kinds:

ValueError: Invalid chart type given hist

why does it say invalid chart type? 为什么说无效的图表类型? the columns are numeric and can be made into histograms. 列是数字的,可以制成直方图。

DataFrame has its own hist method: DataFrame有自己的hist方法:

df =pd.DataFrame({'col1':np.random.randn(100),'col2':np.random.randn(100)})
df.hist(layout=(1,2))   

draws a histogram for each valid column of the dataframe . dataframe每个有效列绘制直方图。

在此输入图像描述

I don't believe 'hist' was a supported type in 0.14.1. 我不相信'hist'是0.14.1中支持的类型。 Try df.hist() instead 请尝试使用df.hist()

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM