Python3获取股票行情数据(中国个股/中国指数/全球指数)

 

#!/usr/local/bin/python3
#coding=utf-8
#source http://www.cnblogs.com/txw1958/

import os, io, sys, re, time, json, base64
import webbrowser, urllib.request


period_All_List = [
                    "min",      #分时线
                    "daily",    #日K线
                    "weekly",   #周K线
                    "monthly"   #月K线
                  ]
period_min = period_All_List[0]
period_daily = period_All_List[1]

ChinaStockIndexList = [
    "000001", # sh000001 上证指数
    "399001", # sz399001 深证成指
    "000300", # sh000300 沪深300
    "399005", # sz399005 中小板指
    "399006", # sz399006 创业板指
    "000003",  # sh000003 B股指数
]
ChinaStockIndividualList = [
    "000063", #  中兴通讯
    "600036", #  招商银行
]

WorldStockIndexList = [
    {'code':"000001", 'yahoo':"000001.SS",'name':{'chinese':"中国上证指数", 'english':"CHINA SHANGHAI COMPOSITE INDEX"}},
    {'code':"399001", 'yahoo':"399001.SZ",'name':{'chinese':"中国深证成指", 'english':"SZSE COMPONENT INDEX"}},
    {'code':"DJI", 'yahoo':"^DJI",'name':{'chinese':"美国道琼斯工业平均指数", 'english':"Dow Jones Industrial Average"}},
    {'code':"IXIC", 'yahoo':"^IXIC",'name':{'chinese':"美国纳斯达克综合指数", 'english':"NASDAQ Composite"},},
    {'code':"GSPC", 'yahoo':"^GSPC",'name':{'chinese':"美国标准普尔500指数", 'english':"S&P 500"}},
    {'code':"N225", 'yahoo':"^N225",'name':{'chinese':"日本日经225指数", 'english':"NIKKEI 225"}},
    {'code':"TWII", 'yahoo':"^TWII",'name':{'chinese':"台湾台北加权指数", 'english':"TSEC weighted index"}},
    {'code':"HSI", 'yahoo':"^HSI",'name':{'chinese':"香港恒生指数", 'english':"HANG SENG INDEX"}},
    {'code':"FCHI", 'yahoo':"^FCHI",'name':{'chinese':"法国CAC40指数", 'english':"CAC 40"}},
    {'code':"FTSE", 'yahoo':"^FTSE",'name':{'chinese':"英国富时100指数", 'english':"FTSE 100"}},
    {'code':"GDAXI", 'yahoo':"^GDAXI",'name':{'chinese':"德国法兰克福DAX指数", 'english':"DAX"}
    }
]
WorldStockIndexList_SP500 =  WorldStockIndexList[7]

#国内股票数据:指数
def getChinaStockIndexInfo(stockCode, period):
    try:
        exchange = "sz" if (int(stockCode) // 100000 == 3) else "sh"
        #http://hq.sinajs.cn/list=s_sh000001
        dataUrl = "http://hq.sinajs.cn/list=s_" + exchange + stockCode
        stdout = urllib.request.urlopen(dataUrl)
        stdoutInfo = stdout.read().decode('gb2312')
        tempData = re.search('''(")(.+)(")''', stdoutInfo).group(2)
        stockInfo = tempData.split(",")
        #stockCode = stockCode,
        stockName   = stockInfo[0]
        stockEnd    = stockInfo[1]  #当前价,15点后为收盘价
        stockZD     = stockInfo[2]  #涨跌
        stockLastEnd= str(float(stockEnd) - float(stockZD)) #开盘价
        stockFD     = stockInfo[3]  #幅度
        stockZS     = stockInfo[4]  #总手
        stockZS_W   = str(int(stockZS) / 100)
        stockJE     = stockInfo[5]  #金额
        stockJE_Y   = str(int(stockJE) / 10000)
        content = "#" + stockName + "#" + "(" + str(stockCode) + ")" + " 收盘:" \
          + stockEnd + ",涨跌:" + stockZD + ",幅度:" + stockFD + "%" \
          + ",总手:" + stockZS_W + "" + ",金额:" + stockJE_Y + "亿" + "  "

        imgPath = "http://image.sinajs.cn/newchart/" + period + "/n/" + exchange + str(stockCode) + ".gif"
        twitter = {'message': content, 'image': imgPath}

    except Exception as e:
        print(">>>>>> Exception: " + str(e))
    else:
        return twitter
    finally:
        None

#国内股票数据:个股
def getChinaStockIndividualInfo(stockCode, period):
    try:
        exchange = "sh" if (int(stockCode) // 100000 == 6) else "sz"
        dataUrl = "http://hq.sinajs.cn/list=" + exchange + stockCode
        stdout = urllib.request.urlopen(dataUrl)
        stdoutInfo = stdout.read().decode('gb2312')
        tempData = re.search('''(")(.+)(")''', stdoutInfo).group(2)
        stockInfo = tempData.split(",")
        #stockCode = stockCode,
        stockName   = stockInfo[0]  #名称
        stockStart  = stockInfo[1]  #开盘
        stockLastEnd= stockInfo[2]  #昨收盘
        stockCur    = stockInfo[3]  #当前
        stockMax    = stockInfo[4]  #最高
        stockMin    = stockInfo[5]  #最低
        stockUp     = round(float(stockCur) - float(stockLastEnd), 2)
        stockRange  = round(float(stockUp) / float(stockLastEnd), 4) * 100
        stockVolume = round(float(stockInfo[8]) / (100 * 10000), 2)
        stockMoney  = round(float(stockInfo[9]) / (100000000), 2)
        stockTime   = stockInfo[31]

        content = "#" + stockName + "#(" + stockCode + ")" + " 开盘:" + stockStart \
        + ",最新:" + stockCur + ",最高:" + stockMax + ",最低:" + stockMin \
        + ",涨跌:" + str(stockUp) + ",幅度:" + str(stockRange) + "%" \
        + ",总手:" + str(stockVolume) + "" + ",金额:" + str(stockMoney) \
        + "亿" + ",更新时间:" + stockTime + "  "

        imgUrl = "http://image.sinajs.cn/newchart/" + period + "/n/" + exchange + str(stockCode) + ".gif"
        twitter = {'message': content, 'image': imgUrl}

    except Exception as e:
        print(">>>>>> Exception: " + str(e))
    else:
        return twitter
    finally:
        None

#全球股票指数
def getWorldStockIndexInfo(stockDict):
    try:
        #http://download.finance.yahoo.com/d/quotes.csv?s=^IXIC&f=sl1c1p2l
        yahooCode = stockDict['yahoo']
        dataUrl = "http://download.finance.yahoo.com/d/quotes.csv?s=" + yahooCode + "&f=sl1c1p2l"

        stdout = urllib.request.urlopen(dataUrl)
        stdoutInfo = stdout.read().decode('gb2312')
        tempData = stdoutInfo.replace('"', '')
        stockInfo = tempData.split(",")
        stockNameCn = stockDict['name']['chinese']
        stockNameEn = stockDict['name']['english']
        stockCode   = stockDict['code']
        stockEnd    = stockInfo[1]  #当前价,5点后为收盘价
        stockZD     = stockInfo[2]  #涨跌
        stockLastEnd= str(float(stockEnd) - float(stockZD)) #开盘价
        stockFD     = stockInfo[3]  #幅度
        percent     = float(stockFD.replace("%", ""))
        matchResult = re.search("([\w?\s?:]*)(\-)", stockInfo[4])  #日期和最新值
        stockDate   = matchResult.group(1)

        content = "#" + stockNameCn + "# " + stockNameEn + "(" + stockCode + ")" \
          + " 当前:" + stockEnd + ", 涨跌:" + stockZD + ", 幅度:" + stockFD \
          + ", 最后交易时间:" + stockDate

        twitter = content

    except Exception as err:
        print(">>>>>> Exception: " + yahooCode + " " + str(err))
    else:
        return twitter
    finally:
        None

def test_china_index_data():
    for stockCode in ChinaStockIndexList:
        twitter = getChinaStockIndexInfo(stockCode, period_daily)
        print(twitter['message'] + twitter['image'])

def test_china_individual_data():
    for stockCode in ChinaStockIndividualList:
        twitter = getChinaStockIndividualInfo(stockCode, period_min)
        print(twitter['message'] + twitter['image'])

def test_global_index_data():
    for stockDict in WorldStockIndexList:
        print(getWorldStockIndexInfo(stockDict))


def main():
    "main function"
    print(base64.b64decode(b'Q29weXJpZ2h0IChjKSAyMDEyIERvdWN1YmUgSW5jLiBBbGwgcmlnaHRzIHJlc2VydmVkLg==').decode())
    test_china_index_data()
    test_china_individual_data()
    test_global_index_data()

if __name__ == '__main__':
    main()

 

 

 

原文出处: http://www.cnblogs.com/txw1958/  

*** Python 3.2.2 (default, Sep  4 2011, 09:51:08) [MSC v.1500 32 bit (Intel)] on win32. ***
>>> 
#上证指数#(000001) 收盘:2128.765,涨跌:2.761,幅度:0.13%,总手:5207.69万,金额:466.8022亿  http://image.sinajs.cn/newchart/daily/n/sh000001.gif
#深证成指#(399001) 收盘:9087.130,涨跌:5.232,幅度:0.06%,总手:626366.6万,金额:475.5102亿  http://image.sinajs.cn/newchart/daily/n/sz399001.gif
#沪深300#(000300) 收盘:2349.108,涨跌:1.620,幅度:0.07%,总手:3109.05万,金额:330.4818亿  http://image.sinajs.cn/newchart/daily/n/sh000300.gif
#中小板指#(399005) 收盘:4289.397,涨跌:-28.691,幅度:-0.66%,总手:40025.33万,金额:52.3716亿  http://image.sinajs.cn/newchart/daily/n/sz399005.gif
#创业板指#(399006) 收盘:703.581,涨跌:-3.144,幅度:-0.44%,总手:18349.6万,金额:30.0858亿  http://image.sinajs.cn/newchart/daily/n/sz399006.gif
#B股指数#(000003) 收盘:217.495,涨跌:-0.164,幅度:-0.08%,总手:23.23万,金额:1.2213亿  http://image.sinajs.cn/newchart/daily/n/sh000003.gif

#中兴通讯#(000063) 开盘:11.35,最新:11.48,最高:11.58,最低:11.30,涨跌:0.14,幅度:1.23%,总手:11.01万,金额:1.26亿,更新时间:15:05:51  http://image.sinajs.cn/newchart/min/n/sz000063.gif
#招商银行#(600036) 开盘:9.62,最新:9.75,最高:9.86,最低:9.62,涨跌:0.16,幅度:1.67%,总手:53.18万,金额:5.18亿,更新时间:15:02:09  http://image.sinajs.cn/newchart/min/n/sh600036.gif

#中国上证指数# CHINA SHANGHAI COMPOSITE INDEX(000001) 当前:2128.765, 涨跌:+2.761, 幅度:+0.13%, 最后交易时间:3:01am 
#中国深证成指# SZSE COMPONENT INDEX(399001) 当前:9087.13, 涨跌:+5.231, 幅度:+0.06%, 最后交易时间:3:00am 
>>>>>> Exception: ^DJI list index out of range
None
#美国纳斯达克综合指数# NASDAQ Composite(IXIC) 当前:2930.03, 涨跌:+36.78, 幅度:+1.27%, 最后交易时间:12:03pm 
#美国标准普尔500指数# S&P 500(GSPC) 当前:1374.55, 涨跌:+14.53, 幅度:+1.07%, 最后交易时间:12:03pm 
#日本日经225指数# NIKKEI 225(N225) 当前:8566.64, 涨跌:+123.54, 幅度:+1.46%, 最后交易时间:2:28am 
#台湾台北加权指数# TSEC weighted index(TWII) 当前:7124.49, 涨跌:+153.80, 幅度:+2.21%, 最后交易时间:1:33am 
#香港恒生指数# HANG SENG INDEX(HSI) 当前:19274.961, 涨跌:+382.172, 幅度:+2.02%, 最后交易时间:4:01am 
#法国CAC40指数# CAC 40(FCHI) 当前:3280.19, 涨跌:+73.07, 幅度:+2.28%, 最后交易时间:11:59am 
#英国富时100指数# FTSE 100(FTSE) 当前:5627.21, 涨跌:+54.05, 幅度:+0.97%, 最后交易时间:11:35am 
#德国法兰克福DAX指数# DAX(GDAXI) 当前:6689.40, 涨跌:+106.44, 幅度:+1.62%, 最后交易时间:11:45am 
>>> 

 

 

 

#Sina 数据
# http://hq.sinajs.cn/list=sh600000
# http://hq.sinajs.cn/list=sz000913

 

#var hq_str_sh601006="大秦铁路, 27.55, 27.25, 26.91, 27.55, 26.20, 26.91, 26.92,
#                     22114263, 589824680, 4695, 26.91, 57590, 26.90, 14700, 26.89,
#                     14300,6.88, 15100, 26.87, 3100, 26.92, 8900, 26.93, 14230,
#                     26.94, 25150, 26.95, 15220, 26.96, 2008-01-11, 15:05:32";

 

   0:”大秦铁路”,股票名字;
   1:”27.55″,今日开盘价;
   2:”27.25″,昨日收盘价;
   3:”26.91″,当前价格;//时间结束后也就是收盘价了
   4:”27.55″,今日最高价;
   5:”26.20″,今日最低价;
   6:”26.91″,竞买价,即“买一”报价;
   7:”26.92″,竞卖价,即“卖一”报价;
   8:”22114263″,成交的股票数,由于股票交易以一百股为基本单位,所以在使用时,通常把该值除以一百;
   9:”589824680″,成交金额,单位为“元”,为了一目了然,通常以“万元”为成交金额的单位,所以通常把该值除以一万;
   10:”4695″,“买一”申请4695股,即47手;
   11:”26.91″,“买一”报价;
   12:”57590″,“买二”
   13:”26.90″,“买二”
   14:”14700″,“买三”
   15:”26.89″,“买三”
   16:”14300″,“买四”
   17:”26.88″,“买四”
   18:”15100″,“买五”
   19:”26.87″,“买五”
   20:”3100″,“卖一”申报3100股,即31手;
   21:”26.92″,“卖一”报价 (22, 23), (24, 25), (26,27), (28, 29)分别为“卖二”至“卖四的情况”
   30:”2008-01-11″,日期;
   31:”15:05:32″,时间;
'''

 

'''
上证综合指数(000001),
http://hq.sinajs.cn/list=s_sh000001  上证综合指数
http://hq.sinajs.cn/list=s_sz399001  深圳成指
var hq_str_s_sh000001=”上证指数,3094.668,-128.073,-3.97,436653,5458126″;
数据含义分别为: 指数名称,当前点数,当前价格,涨跌率,成交量(手),成交额(万元);
    ##['上证指数',  000000
    ##'2377.512', 收盘
    ##'-5.973',   涨跌:
    ##'-0.25',    幅度:
    ##'585346',   总手: /100 万
    ##'5317351']  金额:/1000 亿

 

K线图

 

http://image.sinajs.cn/newchart/daily/n/sh601006.gif   日K线
http://image.sinajs.cn/newchart/min/n/sh000001.gif     分时线
http://image.sinajs.cn/newchart/daily/n/sh000001.gif 日K线
http://image.sinajs.cn/newchart/weekly/n/sh000001.gif 周K线
http://image.sinajs.cn/newchart/monthly/n/sh000001.gif 月K线

 

# 和讯网的图片数据
# http://minpic.quote.stock.hexun.com/WebPic/SH/Min/601669_emb.gif
# http://minpic.quote.stock.hexun.com/WebPic/SZ/Min/000063_emb.gif
'''

Yahoo财经频道获取股票数据的API
http://finance.yahoo.com/d/quotes.csv?s=<股票名称>&f=<数据列选项>
参数s — 表示股票名称,多个股票之间使用英文加号分隔,如“XOM+BBDb.TO+JNJ+MSFT”,罗列了四个公司的股票:XOM, BBDb.TO, JNJ, MSFT。 f — 表示返回数据列,如“snd1l1yr”。
示例
http://finance.yahoo.com/d/quotes.csv?s=XOM+BBDb.TO+JNJ+MSFT&f=snd1l1yr
返回:
"XOM","Exxon Mobil Corpo","10/7/2010",63.85,2.69,12.33
"BBD-B.TO","BOMBARDIER INC., ","10/7/2010",5.27,1.90,N/A
"JNJ","Johnson & Johnson","10/7/2010",63.22,3.26,13.06
"MSFT","Microsoft Corpora","10/7/2010",24.53,2.12,11.68

上述是获取当前最新的数据,若需要获得历史数据,请使用下面API。
http://ichart.yahoo.com/table.csv?s=<string>&a=<int>&b=<int>&c=<int>&d=<int>&e=<int>&f=<int>&g=d&ignore=.csv
参数s — 股票名称 a — 起始时间,月 b — 起始时间,日 c — 起始时间,年 d — 结束时间,月 e — 结束时间,日 f — 结束时间,年 g — 时间周期。Example: g=w, 表示周期是‘周’。d->‘日’(day), w->‘周’(week),m->‘月’(mouth),v->‘dividends only’
一定注意月份参数,其值比真实数据-1。如需要9月数据,则写为08。

示例 查询浦发银行2010.09.25 – 2010.10.8之间日线数据
http://ichart.yahoo.com/table.csv?s=600000.SS&a=08&b=25&c=2010&d=09&e=8&f=2010&g=d
返回:
Date,Open,High,Low,Close,Volume,Adj Close
2010-09-30,12.37,12.99,12.32,12.95,76420500,12.95
2010-09-29,12.20,12.69,12.12,12.48,79916400,12.48
2010-09-28,12.92,12.92,12.57,12.58,63988100,12.58
2010-09-27,13.00,13.02,12.89,12.94,43203600,12.94

深沪股票代码
yahoo的api是国际性的,是支持国内沪深股市的,但代码稍微变动一下,如浦发银行的代号是:600000.SS。规则是:上海市场末尾加.ss,深圳市场末尾加.sz。

—— EOF ——

参考
http://code.google.com/p/yahoo-finance-managed/
http://finance.yahoo.com/
http://www.gummy-stuff.org/Yahoo-data.htm
Python API Class
http://www.goldb.org/ystockquote.html

附录
雅虎股票API f参数对照表
a Ask a2 Average Daily Volume a5 Ask Size
b Bid b2 Ask (Real-time) b3 Bid (Real-time)
b4 Book Value b6 Bid Size c Change & Percent Change
c1 Change c3 Commission c6 Change (Real-time)
c8 After Hours Change (Real-time) d Dividend/Share d1 Last Trade Date
d2 Trade Date e Earnings/Share e1 Error Indication (returned for symbol changed / invalid)
e7 EPS Estimate Current Year e8 EPS Estimate Next Year e9 EPS Estimate Next Quarter
f6 Float Shares g Day’s Low h Day’s High
j 52-week Low k 52-week High g1 Holdings Gain Percent
g3 Annualized Gain g4 Holdings Gain g5 Holdings Gain Percent (Real-time)
g6 Holdings Gain (Real-time) i More Info i5 Order Book (Real-time)
j1 Market Capitalization j3 Market Cap (Real-time) j4 EBITDA
j5 Change From 52-week Low j6 Percent Change From 52-week Low k1 Last Trade (Real-time) With Time
k2 Change Percent (Real-time) k3 Last Trade Size k4 Change From 52-week High
k5 Percebt Change From 52-week High l Last Trade (With Time) l1 Last Trade (Price Only)
l2 High Limit l3 Low Limit m Day’s Range
m2 Day’s Range (Real-time) m3 50-day Moving Average m4 200-day Moving Average
m5 Change From 200-day Moving Average m6 Percent Change From 200-day Moving Average m7 Change From 50-day Moving Average
m8 Percent Change From 50-day Moving Average n Name n4 Notes
o Open p Previous Close p1 Price Paid
p2 Change in Percent p5 Price/Sales p6 Price/Book
q Ex-Dividend Date r P/E Ratio r1 Dividend Pay Date
r2 P/E Ratio (Real-time) r5 PEG Ratio r6 Price/EPS Estimate Current Year
r7 Price/EPS Estimate Next Year s Symbol s1 Shares Owned
s7 Short Ratio t1 Last Trade Time t6 Trade Links
t7 Ticker Trend t8 1 yr Target Price v Volume
v1 Holdings Value v7 Holdings Value (Real-time) w 52-week Range
w1 Day’s Value Change w4 Day’s Value Change (Real-time) x Stock Exchange
y Dividend Yield


 

 

posted @ 2012-07-28 00:16  方倍工作室  阅读(30472)  评论(0编辑  收藏  举报