1

我是 Python 和 matplotlib 的初学者,但我正在努力学习!我想使用 matplotlib 从包含频率的日期的 CSV 中绘制一些简单的数据。X 轴包含日期,Y 轴包含频率。来自 CSV 的示例数据:

2011/12/15,5
2011/12/11,4
2011/12/19,2

我检查了“matplotlib.sf.net/examples”,但似乎所有测试数据都是从 http get 下载的。如果有人能用一些示例代码指导我如何读入(可能使用 CSV 阅读器)并在图表中显示数据,我将不胜感激。

谢谢!!

4

2 回答 2

2

也许您正在寻找类似的东西:

import csv
import datetime as dt
import matplotlib.pyplot as plt

arch = 'C:\\Python26\\programas\\test.csv'
data = csv.reader(open(arch))

data = [(dt.datetime.strptime(item, "%Y/%m/%d"), float(value)) for item, value in data]
data.sort()
[x, y] = zip(*data)

fig = plt.figure()
ax = fig.add_subplot(111)
ax.plot(x, y)

ax.grid(True)
fig.autofmt_xdate()

plt.show()

在此处输入图像描述

于 2012-04-17T23:42:36.263 回答
1

我试图让我的代码尽可能简单,这绝不是优雅的,但你去吧:

import csv
import matplotlib.pyplot as plt

### Making test CSV file ###
data = [['2011/12/15,5'],['2011/12/11,4'],['2011/12/19,2'],['2011/12/16,3'],['2011/12/20,8'],['2011/12/14,4'],['2011/12/10,10'],['2011/12/9,7']]
with open('test.csv', 'wb') as f:
    writer = csv.writer(f)
    for i in data:
        writer.writerow(i)


### Extract data from CSV ###
with open('test.csv', 'rb') as n:
    reader = csv.reader(n)
    dates = []
    freq = []
    for row in reader:
        values = row[0].split(',')
        dates.append(values[0])
        freq.append(values[1])          


### Do plot ###
false_x = [x for x in range(len(dates))]
plt.plot(false_x,freq, 'o-')
plt.xticks(range(len(dates)), (dates), rotation=45)
# plt.axis([xmin, xmax, ymin, ymax]) - sets axes limits on graph
plt.axis([-1, 8, 0, 11])
plt.show()

这使得:

在此处输入图像描述

于 2012-04-17T23:33:36.430 回答