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

2024-05-11 13:04

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'))

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

2. 怎么获取股票实时数据呢?开发炒股软件用

1,从证券交易所获取,比较难
2.从证券公司获取,一般
3.和其他获得,如财讯网合作通过他获得,较易

3. 现在的股票软件数据是怎么来的?

这些有一些就能按照我们平常看的K线或其它的指标..电脑选股..
  但基本上是骗人的...如果是行的话..每个人花点钱去炒股不就发了?

因为我之前也在这一类型的公司工作过.. 知道他们是怎么一回事.
 当然为了生活.我也骗过人..有二万的软件.有一万的软件.一听就知道有问题了..
  
  股市没高手...      如果你懂庄家什么时候卖买? 就能赚钱.
股市可以人为控制....不像外汇...
中国一天成交一千多亿...    外汇一天成交二万亿..没人能控制
市场透明化..公平公正...但风险大..

现在的股票软件数据是怎么来的?

4. 想要开发一个股票交易软件 需要怎样获取实时数据 数据接口

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

5. 开发炒股软件,从哪里获得股票数据

目前市场上有很多股票行情交易软件,各种软件提供了丰富的分析和展示功能,而且基本上是免费的。但这些数据都是在线的、无法统一地下载到本地进行分析,于是上网找了些资料,有的是将程序到新浪搜狐的财经频道或其他财经类网站抓取并分析网页,这种方法操作性不强而且准确率较低,遇到广告或网页变动时风险较大。于是找到了Sina股票数据接口,这个接口是通过在IE端输入"http://hq.sinajs.cn/list="+相应股票代码网站返回一个文件形式的数据,也可以通过JS获取该文件中的变量得到想要的数据字符串。
        以大秦铁路(股票代码:601006)为例,如果要获取它的最新行情,只需访问新浪的股票数据接口:http://hq.sinajs.cn/list=sh601006这个url会返回一串文本,例如:
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,
 26.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开始。
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″,时间;
        相应地,也可以获得深市相关股票信息,但是这种方法的弊病是只能获得最新的或者是当天的股票数据,无法将历史数据导入到数据库,当然,你也可以以某一天为起始点自己重新创造历史数据。所以继续寻找其他网站接口,终于找到了雅虎财经网站,它提供的接口可以直接把股票历史数据导成Excel,真实太方便了!直接在浏览器地址中数据网址即可http://table.finance.yahoo.com/table.csv?s=股票代码,但是如果手动输入再逐一下载保存简直是太麻烦了,光上证股票就800多个,估计刚手动下载完就又开盘了还得重新下载。所以我的思路是,1、利用多线程方法下载股票文件。2、将这些文件统一导入数据库。
1.1文件下载类:
import java.io.*;
import java.net.*;
import java.util.List;
import fatowen.stocksystem.sysconfig.data.DownLoadVO;
public class HttpDownFile {
 private static int BUFFER_SIZE = 8096;
 /**根据URL下载文件并保存
 * @param destUrl String
 * @param fileName String
 * @throws Exception
 */
 public void saveToFile(String destUrl, String fileName) throws IOException {
 
  FileOutputStream fos = null;
  BufferedInputStream bis = null;
  HttpURLConnection httpUrl = null;
  URL url = null;
  byte[] buf = new byte[BUFFER_SIZE];
  int size = 0;
 
  url = new URL(destUrl);
  httpUrl = (HttpURLConnection) url.openConnection();
  httpUrl.connect();
  bis = new BufferedInputStream(httpUrl.getInputStream());
  fos = new FileOutputStream(fileName);
  while ((size = bis.read(buf)) != -1)
   fos.write(buf, 0, size);
  fos.close();
  bis.close();
  httpUrl.disconnect();
 }
}
1.2多线程实现下载类:
import java.util.ArrayList;
import java.util.List;
public class HisDataAddThread extends Thread {
 boolean runFlag = true;
 List myParamList = null;
 String downLoadData ="";
 String baseUrl = "http://table.finance.yahoo.com/table.csv?s=";
 String result = "";
 String savePath = "";
 
 public HisDataAddThread(List paramList,String savePath){
  this.myParamList = paramList;
  this.savePath = savePath;
 }
 
 public void run() {
 
  while(runFlag){
   downLoadData = PublicDataUtil.getDownLoadData(myParamList);
   if(!Lib.isEmpty(downLoadData)){
    HttpDownFile oInstance = new HttpDownFile();
    try {
     oInstance.saveToFile(baseUrl + downLoadData, savePath + downLoadData + ".csv");
    }catch (Exception err) {
     System.out.println(err.toString());
    }
   }else{
    runFlag = false;
   }
   try {
    Thread.sleep(1000);
   } catch (InterruptedException e) {
    e.printStackTrace();
   }
  }
 }
 public List getFailureList() {
  return failureList;
 }
 public void setFailureList(List failureList) {
  this.failureList = failureList;
 }
 public List getSuccessList() {
  return successList;
 }
 public void setSuccessList(List successList) {
  this.successList = successList;
 }
}
2.将下载完的文件统一保存到数据库工具类
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class CSVUtitl {
 private BufferedReader bufferedreader = null;
 private List list = new ArrayList();
 
 public CSVUtitl(){
 }
 public CSVUtitl(String filename) throws IOException{
       bufferedreader = new BufferedReader(new FileReader(filename));
       String stemp;
       while((stemp = bufferedreader.readLine()) != null){
           list.add(stemp);
       }
 }
 public List getList() throws IOException {
        return list;
 }
 // 得到csv文件的行数
 public int getRowNum(){
     return list.size();
 }
    //得到csv文件的列数
 public int getColNum(){
       if(!list.toString().equals("[]")) {
      
         //csv文件中,每列之间的是用','来分隔的
            if(list.get(0).toString().contains(",")) { 
                return list.get(0).toString().split(",").length;
            }else if(list.get(0).toString().trim().length() != 0) {
                return 1;
            }else{
                return 0;
            }
       }else{
            return 0;
        }
 }
 
    //取得指定行的值
 public String getRow(int index) {
     if (this.list.size() != 0)
      return (String) list.get(index);
     else                      
      return null;
 }
 //取得指定列的值
 public String getCol(int index){
       if (this.getColNum() == 0){
                return null;
       }
      
       StringBuffer scol = new StringBuffer();
       String temp = null;
       int colnum = this.getColNum();
     
       if (colnum > 1){
          for (Iterator it = list.iterator(); it.hasNext();) {
             temp = it.next().toString();
             scol = scol.append(temp.split(",")[index] + ",");
          }
       }else{
          for (Iterator it = list.iterator(); it.hasNext();) {
            temp = it.next().toString();
            scol = scol.append(temp + ",");
          }
       }
       String str=new String(scol.toString());
       str = str.substring(0, str.length() - 1);
       return str;
 }
 //取得指定行,指定列的值
 public String getString(int row, int col) {
        String temp = null;
        int colnum = this.getColNum();
        if(colnum > 1){
            temp = list.get(row).toString().split(",")[col];
        }else if(colnum == 1) {
            temp = list.get(row).toString();
        }else{
            temp = null;
        }
            return temp;
 }

 public void CsvClose() throws IOException {
     this.bufferedreader.close();
 }
 public void run(String filename) throws IOException {
        
  CSVUtitl cu = new CSVUtitl(filename);
     for(int i=0;i<cu.getRowNum();i++){
           String SSCCTag = formatData(cu.getString(i,1));//得到第i行.第一列的数据.
           String SiteName = formatData(cu.getString(i,2));//得到第i行.第二列的数据.
           String StationId= formatData(cu.getString(i,3));
          
           //将数据保存到数据库中
           ... ...
           ... ...
           ... ...
     }
     cu.CsvClose();
 }
 public String formatData(String baseData){
 
  String result = null;
  if(!"".equals(baseData) && baseData != null){
   if(baseData.length() > 1){
    result = baseData.substring(1,baseData.length());
    result = result.substring(0, result.length()-1);
   }else{
    result = baseData;
   }
  }else{
   result = "";
  }
  return result.trim();
 }
 
 public static void main(String[] args) throws IOException {
  CSVUtitl test = new CSVUtitl();
  try{
   File path = new File("e:\\data");
   File[] f = path.listFiles();
   List l = new ArrayList();
   for(int i=0;i<f.length;i++){
    if(f[i].getName().endsWith(".csv"))
    l.add(f[i]); www.2cto.com
   }
   Iterator it = l.iterator();
   while(it.hasNext()){
    File ff = (File)it.next();
    test.run(path.toString()+File.separator+ff.getName());
   }
         }catch (Exception e){
     
   }
  }
}

开发炒股软件,从哪里获得股票数据

6. 股票软件的实时数据是来源自哪里

证券交易所的数据库

7. 开发股票交易软件,实时交易数据从哪里获取?券商接口怎么做?

聚合数据上有股票数据接口 也有港股信息api 直接调用就行

开发股票交易软件,实时交易数据从哪里获取?券商接口怎么做?

8. 如何实时获取大智慧之类股票软件的数据源

我的股票分析软件组合是: 大智慧+谦穗 
1、看盘用谦穗超强版,因为谦穗超强版提供的信息多,尤其是盘中能实时的发出买卖点提示。
2、大智慧提供了重要的交易信息——股东数。谦穗的风险提示和彪股指标都能反映个股每日动向,这些功能有重要的参考价值。
最新文章
热门文章
推荐阅读