繁体   English   中英

matplotlib图yahoo图api图图

[英]matplotlib plot yahoo chart api graph plot

我只是开始学习matplotlib。 我正在尝试绘制Yahoo Char API地块股票。 我正在尝试该程序,但无法正常工作。

import numpy as np 
import matplotlib.pyplot as plt 
import matplotlib.dates as mdates

def graph():
    date, closep, highp, lowp, openp, valuep = np.loadtxt('/home/najeeb/Desktop/table.csv', delimiter=',', unpack=True,
                          converters={0: mdates.strpdate2num('%Y-%m-%d')})

   fig = plt.figure()
   ax1 = fig.add_subplot(1,1,1, axisbg='w')
   plt.plot_date(x=date, y=value, fmt='-')

   plt.title('title')
   plt.ylabel('value')
   plt.xlabel('date')
   plt.show()
graph()

这是CSV文件

请指导我如何解决这个问题,还有另一种方法绘制股票图...谢谢

CSV文件如下所示:

Date,Open,High,Low,Close,Volume,Adj Close
2014-10-17,97.50,99.00,96.81,97.67,68032200,97.67
2014-10-16,95.55,97.72,95.41,96.26,72110700,96.26
2014-10-15,97.97,99.15,95.18,97.54,100875400,97.54

您的代码np.loadtxt()试图将标头'Date'解析为日期,该方法不起作用,因为该字符串不是有效的日期值,因此我使用skiprows=1来跳过标头。

另一个问题是,CSV有7列,而在您的元组中,您仅拆包了6个值

在此处输入图片说明

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
import urllib2


url = 'http://ichart.finance.yahoo.com/table.csv?s=AAPL&d=9&e=14&f=2008&g=d&a=8&b=7&c=1984&ignore=.csv'

def graph():
    date, open, high, low, close, volume, adj_close = np.loadtxt(urllib2.urlopen(url), skiprows=1, delimiter=',', unpack=True, converters={0: mdates.strpdate2num('%Y-%m-%d')})

    fig = plt.figure()
    ax1 = fig.add_subplot(1,1,1, axisbg='w')
    plt.plot_date(x=date, y=adj_close, fmt='-')

    plt.title('Apple, 1984 to 2008')
    plt.ylabel('Adjusted close')
    plt.xlabel('Date')
    plt.show()

graph()

暂无
暂无

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

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