如何编程从免费股票软件中提取实时数据?

如何编程从免费股票软件中提取实时数据?,第1张

自己写程序的话,一种方法是从已提供的信息源,例如webservice获取数据。还有种办法就是去连游胡粗接提供即时信息的网页硬解析。

代码举例如下:

Created on Thu Jul 23 09:17:27 2015

@author: jet

"""

DAY_PRICE_COLS = ['date', 'open', 'high', 'close', 'low', 'volume',

'chg', '%chg', 'ma5', 'ma10', 'ma20',

'vma5', 'vma10', 'vma20', 'turnover']

DAY_PRICE_URL = '%sapi.finance.%s/做敏%s/?code=%s&type=last'

INDEX_KEY = ['SH', 'SZ', 'HS300', 'SZ50', 'GEB', 'SMEB']

INDEX_LIST = {'SH': 'sh000001', 'SZ': 'sz399001', 'HS300': 'sz399300',

'SZ50': 'sh000016', 'GEB': 'sz399006', 'SMEB': 'sz399005'}

INDEX_DAY_PRICE_COLS= ['date', 'open', 'high', 'close', 'low', 'volume',

'chg', '%chg', 'ma5', 'ma10', 'ma20',

'vma5', 'vma10', 'vma20']

K_TYPE_KEY = ['D', 'W', 'M']

K_TYPE_MIN_KEY = ['5', '15', '30', '60']

K_TYPE = {'D': 'akdaily', 'W': 'akweekly', 'M': 'akmonthly'}

MIN_PRICE_URL = '%sapi.finance.%s/akmin?scode=%s&type=%s'

PAGE_TYPE = {'http': 'http://', 'ftp': 'ftp://'}

PAGE_DOMAIN = {'sina': 'sina.com.cn', 'ifeng': 'ifeng.com'}

URL_ERROR_MSG = '获取失败,请检查网络状态,或者API端口URL已经不匹配!'

get_hist_data.py

# -*- coding: utf-8 -*-

"""

Created on Thu Jul 23 09:15:40 2015

@author: jet

"""

import const as ct

import pandas as pd

import json

from urllib2 import urlopen,Request

def get_hist_data(code = None, start = None, end = None, ktype = 'D'):

"""

功能:

获取个股历史交易数据

--------

输入:

--------

code:string

股票代码 比如:601989

start:string

开始日期 格式:YYYY-MM-DD 为空时取到API所提供的最早日期数据

end:string

结束日期 格式:YYYY-MM-DD 为空时取到最近一个交易日数据

ktype:string(default=D, 函数内部自动统一为大写)

数据类型 D=日K线,W=周K线,M=月K线,5=5分钟,15=15分钟

30=30分钟,60=60分钟

输出:

--------

DataFrame

date 日期

open 开盘价

high 最高价

close 收盘价

low 最低价

chg 涨跌额

p_chg 涨跌幅

ma5 5日均

ma10 10日均价

ma20 20日均价

vma5 5日均量

vma10 10日均量

vma20 20日均量

turnover换手率(指数无此项)

"""

code = code_to_APIcode(code.upper())

ktype = ktype.upper()

url = ''

url = get_url(ktype, code)

print(url)

js = json.loads(ping_API(url))

cols = []

if len(js['神镇record'][0]) == 14:

cols = ct.INDEX_DAY_PRICE_COLS

else:

cols = ct.DAY_PRICE_COLS

df = pd.DataFrame(js['record'], columns=cols)

if ktype in ct.K_TYPE_KEY:

df = df.applymap(lambda x:x.replace(u',', u''))

for col in cols[1:]:

df[col]=df[col].astype(float)

if start is not None:

df = df [df.date >= start]

if end is not None:

df = df[df.date <= end]

df = df.set_index('date')

return df

def code_to_APIcode(code):

"""

功能:

验证输入的股票代码是否正确,若正确则返回API对应使用的股票代码

"""

print(code)

if code in ct.INDEX_KEY:

return ct.INDEX_LIST[code]

else:

if len(code) != 6:

raise IOError('code input error!')

else:

return 'sh%s'%code if code[:1] in ['5', '6'] else 'sz%s'%code

def get_url(ktype, code):

"""

功能:

验证输入的K线类型是否正确,若正确则返回url

"""

if ktype in ct.K_TYPE_KEY:

url = ct.DAY_PRICE_URL % (ct.PAGE_TYPE['http'], ct.PAGE_DOMAIN['ifeng'],

ct.K_TYPE[ktype], code)

return url

elif ktype in ct.K_TYPE_MIN_KEY:

url = ct.MIN_PRICE_URL % (ct.PAGE_TYPE['http'], ct.PAGE_DOMAIN['ifeng'],

code, ktype)

return url

else:

raise IOError('ktype input error!')

def ping_API(url):

"""

功能:

向API发送数据请求,若链接正常返回数据

"""

text = ''

try:

req = Request(url)

text = urlopen(req,timeout=10).read()

if len(text) <15:

raise IOError('no data!')

except Exception as e:

print(e)

else:

return text

#测试入口

print(get_hist_data('601989','2015-07-11','2015-07-22'))

不够详细。哦,原来是这样,那得用程序悔闷山语言编写。而碧中且据我所知,博弈大师是不行的。你有程序化端口。你用文华财经吧,当然,这是要罩尘开通的,要收费。这么卖力的回答,记得给好评哈。

朋友,没用的,编完了也做不了程序化交易。因为,接口要钱的。

惠德赢策 大家慧或记住了啊,这个垃圾桐碧老公司老板叫:祝清。公司内部垃圾就算了,公司出的产品都是骗人的,还有他们开局升发的一个模拟炒股的网站要交钱才能炒股,都是骗人的,大家千万别上当受骗,这家公司老板超级卑鄙,合伙别人把他原来的公司给搞垮自己开公司,不过心在自己公司也快倒闭了,员工工资都发布出来了,哈哈,真鸡-巴爽呀,那个B儿子真没话说了。

我就是受害者呀,喷血相告,切记呀


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12437255.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存