2013-03-27 142 views
0

所以我写了一个python应用程序来获取highcharts的股票数据。我在终端Highcharts not rendering

127.0.0.1 - - [28/Mar/2013 13:47:02] "GET/HTTP/1.1" 200 - 
127.0.0.1 - - [28/Mar/2013 13:47:02] "GET /favicon.ico HTTP/1.1" 404 - 
127.0.0.1 - - [28/Mar/2013 13:47:15] "GET /json/msft/?startdate=2010-01-01?enddate=2011-01-01 HTTP/1.1" 200 - 

这里得到这个是我的javascript代码

<script type="text/javascript"> 
function stock() { 
console.log('pass 1') 
url = 'http://127.0.0.1:5000/json/' + document.getElementById("ticker").value + '/?startdate=' + document.getElementById("startdate").value + '?enddate=' + document.getElementById("enddate").value 
$.getJSON(url, function(data) { 
    console.log('pass 2') 
    // split the data set into ohlc and volume 
    var ohlc = [], 
     volume = [], 
     dataLength = data.length; 

    for (i = 0; i < dataLength; i++) { 
     ohlc.push([ 
      data[i]["date"], // the date 
      data[i]["open"], // open 
      data[i]["high"], // high 
      data[i]["low"], // low 
      data[i]["close"] // close 
     ]); 

     volume.push([ 
      data[i]["date"], // the date 
      data[i]["volume"] // the volume 
     ]) 
    } 

    // set the allowed units for data grouping 
    var groupingUnits = [[ 
     'week',       // unit name 
     [1]        // allowed multiples 
    ], [ 
     'month', 
     [1, 2, 3, 4, 6] 
    ]]; 

    // create the chart 
    $('#container').highcharts('StockChart', { 

     rangeSelector: { 
      selected: 1 
     }, 

     title: { 
      text: 'AAPL Historical' 
     }, 

     yAxis: [{ 
      title: { 
       text: 'OHLC' 
      }, 
      height: 200, 
      lineWidth: 2 
     }, { 
      title: { 
       text: 'Volume' 
      }, 
      top: 300, 
      height: 100, 
      offset: 0, 
      lineWidth: 2 
     }], 

     series: [{ 
      type: 'candlestick', 
      name: 'AAPL', 
      data: ohlc, 
      dataGrouping: { 
       units: groupingUnits 
      } 
     }, { 
      type: 'column', 
      name: 'Volume', 
      data: volume, 
      yAxis: 1, 
      dataGrouping: { 
       units: groupingUnits 
      } 
     }] 
    }); 
}); 
} 
</script> 

并为JSON请求

@app.route('/json/<ticker>/', methods = ['GET']) 
def json_route(ticker): 
startdate = request.args.get('startdate','') 
enddate = request.args.get('enddate','') 
check = datecheck(startdate,enddate) 
if check != 'pass': 
    return check 
check = datacheck(ticker,startdate,enddate) 
if check != 'got data': 
     urldata(ticker) 
print '-----------------data-----------------' 
conn = engine.connect() 
entries = conn.execute(select([Stocks]).where(Stocks.symbol == ticker).where(Stocks.date.between(startdate,enddate))).fetchall() 
stocklist = [] 
print entries 
for x in entries: 
    stocklist.append({ 
     'volume': float('%f' %x[7]), 
     'high': float('%.2f' %x[4]), 
     'open': float('%.2f' %x[3]), 
     'low': float('%.2f' %x[5]), 
     'close': float('%.2f' %x[6]), 
     'date': str(x[2]), 
     'stock': x[1], 
        }) 
conn.close() 
return json.dumps(stocklist) 

我的Python代码我在做什么错?我认为getjson将是可行的,如果它在同一个域本地主机上。只有console.log('pass one')在检查元素时工作并显示在控制台中。通过二是永远不会被击中。

回答

4

通过错误消息“仅支持HTTP”来判断,它需要一个HTTP URL。您是否尝试过:

url = 'http://127.0.0.1:5000/json/... 
+0

虽然它不会再给我一个错误,但它也不会从url中获得json。需要它在本地主机上工作。 – 2013-03-27 21:07:31

+1

不知道这是否会有所帮助,但是flask有jsonify的辅助函数用于json响应,它将添加相应的内容类型标头:http://flask.pocoo.org/docs/api/#returning-json – Smoe 2013-03-27 22:17:48

+0

@Smoe运作良好,但仍然没有达到二传或呈现高位 – 2013-03-28 17:54:38