2015-11-05 134 views
0

我正在绘制一个文本文件中的数据,其中两列由逗号分隔。第一列是格式化为%H:%S的时间。第二行是数字。在Python中格式化X轴时间

现在,我的编码显示的是%Y%m%d %H:%M:%s而不是%H:%M。正如你所看到的,有很多条目,它们彼此重叠。我怎样才能让蜱跳过每1或2,使时间更加明显?

我该如何解决这个问题?

文件内容:

09:30,33.89 
09:34,34.17 
09:39,34.41 
09:44,34.20 
09:49,34.40 

脚本:

#!/usr/bin/python 
from __future__ import division 
import sys 
import csv 
import matplotlib 
matplotlib.use('Agg') 
import matplotlib.pyplot as plt 
import datetime as dt 
import numpy as np 

homedir = '/home//' 

ymd = sys.argv[1] 
sym = sys.argv[2] 

x,y = [],[] 
csv_reader = csv.reader(open(homedir + 'finance/data/' + sym + '_' + ymd)) 
for line in csv_reader: 
    x.append(dt.datetime.strptime(line[0], '%H:%M')) 
    y.append(str(line[1])) 

fig = plt.figure() 
ax = fig.add_subplot(111) 

#ax.grid(which='both') 

ax.plot(x,y,'-',ms=3,linewidth=1) 
#fig.autofmt_xdate(x,rotation=90,ha='center') 
plt.xticks(x, x, rotation=90,ha='center') 
plt.title('Daily Market Data for ' + sym + ' on ' + ymd) 
plt.ylabel('Stock Price [$]') 
plt.xlabel('Time of Day') 
plt.grid(True) 

fig.set_size_inches(9,5) 

plt.savefig(homedir + 'finance/' + sym + '_' + ymd + '.png', dpi = 300, bbox_inches='tight') 
#plt.show() 

简介:

enter image description here

+0

形象被打破。 –

+0

刚刚重新上传的情节。 –

+0

这可能有所帮助:http://matplotlib.org/api/dates_api.html#matplotlib.dates.DateFormatter –

回答

2

datetime.strptime()使用第二个参数将字符串时间解析为datetime对象,以将原始字符串中的值映射到datetime组件。这里有一些指南解释了strptime()strftime()之间的区别。

无论如何,我想你可以使用原始字符串作为你的xticks,并留下一行为你的情节单独建立x列表,因为它似乎工作正常。

试着改变你的for环节这样的:

x,y,xticks = [],[],[] 
csv_reader = csv.reader(open(homedir + 'finance/data/' + sym + '_' + ymd)) 
for line in csv_reader: 
    xticks.append(line[0]) 
    x.append(dt.datetime.strptime(line[0], '%H:%M')) 
    y.append(str(line[1])) 

然后,当然,摆脱你的其他xticks分配和改变你的plt.xticks调用此:

plt.xticks(x, xticks, rotation=90,ha='center') 

编辑:OP在这个问题中,我会给出一些简要的建议。

也许做一些哈克在您for循环像

for line in csv_reader: 
    time = dt.datetime.strptime(line[0], '%H:%M') 
    if time.minute % 5 == 0: 
     xticks.append(line[0]) 
    else: 
     xticks.append("") 
    x.append(time) 
    y.append(str(line[1])) 
+0

嗨Jason。感谢您的答复!我忘了提及我希望x轴是'%H:%M'次,而不是我在xticks数组中定义的。仍然获得%Y%m%d%H:%M:%s而不是%H:%M ... –

+0

您是否摆脱了制作“xticks”列表的行?注意在我的答案的'for'循环中,它正在加载一个新的空的'xticks'列表。现在针对刚刚添加到您的问题中的其他问题,我将进行编辑。 – Jason

+0

Doh!忘了删除以前定义的xticks数组。这对于将%Y%m%d%H:%M:%s降到%H:%M完美无缺! –