我有一组数据,我用panda数据框加载到python中,我想做的是创建一个循环,打印所有元素在各自框架中的图表,而不是所有元素在一个框架中的图表,我的数据保存在一个excel文件中,文件结构如下:
Index | DATE | AMB CO 1 | AMB CO 2 |...|AMB CO_n | TOTAL
1 | 1/1/12| 14 | 33 |...| 236 | 1600
. | ... | ... | ... |...| ... | ...
. | ... | ... | ... |...| ... | ...
. | ... | ... | ... |...| ... | ...
n
这是我目前所拥有的代码:
import pandas as pd
import matplotlib.pyplot as plt
ambdf = pd.read_excel('Ambulance.xlsx',
sheetname='Sheet2', index_col=0, na_values=['NA'])
print type(ambdf)
print ambdf
print ambdf['EAS']
amb_plot = plt.plot(ambdf['EAS'], linewidth=2)
plt.title('EAS Ambulance Numbers')
plt.xlabel('Month')
plt.ylabel('Count of Deliveries')
print amb_plot
for i in ambdf:
print plt.plot(ambdf[i], linewidth = 2)
我正在考虑做这样的事情:
for i in ambdf:
ambdf_plot = plt.plot(ambdf, linewidth = 2)
以上不是我想要的,它源于我对Pandas,Matplotlib等的不熟悉,看一些文档,虽然对我来说,它看起来像matplotlib甚至不需要(问题2)
那么,A)我如何为df中的每一列生成一个数据图,B)我需要使用matplotlib还是应该使用panda来完成这一切?
谢谢你,
6条答案
按热度按时间2eafrhcq1#
好的,创建多个图的最简单方法是:
请注意,每次都需要创建一个
figure
,否则pyplot
将在创建的第一个中绘图。如果要创建多个数据系列,只需:
你可以通过一个像
['r','g','b','k']
这样的颜色列表来自动化它,然后只要调用这个列表中的条目和相应的数据就可以了。如果你只是想通过编程将数据序列添加到一个绘图中,类似下面这样的操作就可以了(每次都不会创建新的图形,所以所有的东西都绘制在同一个图形中):如果说有什么不同的话,matplotlib有一个非常好的documentation page,有很多examples。
2019年12月17日添加了
plt.show()
和plt.figure()
调用,以阐明这部分内容。yacmzcpb2#
使用字典!!
也可以使用字典,以便对图进行更多控制:
现在,您可以轻松地选择要修改的图:
当然,由您决定如何处理这些图。您可以将其保存到磁盘
figs[idx].savefig("plot_%s.png" %idx)
或显示plt.show()
。如果要一起弹出所有图,请使用参数block=False
only(如果你有很多情节,这可能会相当混乱)。您可以在loop_plot
函数内部或使用该函数提供的字典在单独的循环中执行此操作。仅将
return
添加到figs
和axs
并不强制执行plt.show()
。ldioqlga3#
以下是两个如何在单独窗口(框架)中生成图形的示例,以及一个如何生成图形并将其保存到单独图形文件中的示例。
好的,首先是屏幕上的例子,注意我们为每个图形使用了一个单独的plt.figure()示例,使用plt.plot(),最后,我们必须调用**plt.show()**将所有图形显示在屏幕上。
另一种方法是plt.show在循环中使用www.example.com(block=False):
现在,让我们生成图形,并将它们分别写入文件。这里我们将plt.show()替换为plt.savefig(filename)。与上一个示例的不同之处在于,我们不必考虑每个图形的“阻塞"。还要注意,我们对文件名进行编号。这里我们使用%03d,以便以后可以方便地按编号顺序使用它们。
q1qsirdb4#
如果您的要求是针对一列绘图,那么请随意使用(首先将数据导入PandasDF)(绘制一个5列和所需行数的绘图矩阵)
:
6ljaweal5#
在不同帧上绘图的简单方法如下所示:
然后python将为每次迭代绘制多个帧。
mxg2im7a6#
我们可以创建一个for循环,并将所有数值列传递给它。当我们将**plt.figure()**包含到循环中时,循环将在单独的窗格中逐个绘制图形。