在量化分析领域,实时且准确的数据接口是成功的基石。经过多次实际测试,我将已确认可用的数据接口分享给正在从事量化分析的朋友们,希望能够对你们的研究和工作有所帮助,接下来我会用Python、JavaScript(Node.js)、Java、C#和Ruby五种主流语言的实例代码给大家逐一演示一下如何获取各类股票数据。
在下方,所有演示中的API接口Url链接结尾的ZHITU_TOKEN_LIMIT_TEST,均为数据请求token证书,因为这个证书是官方测试证书,仅可用于验证各个接口的有效性,所以这个证书限制了只可请求股票代码为000001的数据,正式环境中是不能使用的,证书可以自己去申请一个替换掉就好了(证书是免费申请的),替换成自己申请的证书就可以请求任何股票数据了。
1、python
import requests
url = "https://api.zhituapi.com/hs/gs/yjyg/000001?token=ZHITU_TOKEN_LIMIT_TEST"
response = requests.get(url)
data = response.json()
print(data)
2、JavaScript (Node.js)
const axios = require('axios');
const url = "https://api.zhituapi.com/hs/gs/yjyg/000001?token=ZHITU_TOKEN_LIMIT_TEST";
axios.get(url)
.then(response => {
console.log(response.data);
})
.catch(error => {
console.log(error);
});
3、Java
import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.io.IOException;
public class Main {
public static void main(String[] args) {
HttpClient client = HttpClient.newHttpClient();
HttpRequest request = HttpRequest.newBuilder()
.uri(URI.create("https://api.zhituapi.com/hs/gs/yjyg/000001?token=ZHITU_TOKEN_LIMIT_TEST"))
.build();
try {
HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString());
System.out.println(response.body());
} catch (IOException | InterruptedException e) {
e.printStackTrace();
}
}
}
4、C#
using System;
using System.Net.Http;
using System.Threading.Tasks;
class Program
{
static async Task Main()
{
using (HttpClient client = new HttpClient())
{
string url = "https://api.zhituapi.com/hs/gs/yjyg/000001?token=ZHITU_TOKEN_LIMIT_TEST";
HttpResponseMessage response = await client.GetAsync(url);
string responseBody = await response.Content.ReadAsStringAsync();
Console.WriteLine(responseBody);
}
}
}
5、Ruby
require 'net/http'
require 'json'
url = URI("https://api.zhituapi.com/hs/gs/yjyg/000001?token=ZHITU_TOKEN_LIMIT_TEST")
http = Net::HTTP.new(url.host, url.port)
request = Net::HTTP::Get.new(url)
response = http.request(request)
data = JSON.parse(response.read_body)
puts data
返回的数据:
[{"pdate":"2023-01-17","rdate":"2022-12-31","type":"预升","abs":"预计2022年1-12月归属于上市公司股东的净利润为:45516百万,与上年同期相比变动幅度:25.3%。","old":"1.7300"},{"pdate":"2022-01-14","rdate":"2021-12-31","type":"预升","abs":"预计2021年1-12月归属于上市公司股东的净利润为:36336百万,与上年同期相比变动幅度:25.6%。","old":"1.4000"},{"pdate":"2020-01-14","rdate":"2019-12-31","type":"预升","abs":"预计2019年1-12月归属于上市公司股东的净利润为:28195百万,与上年同期相比变动幅度:13.6%。","old":"1.3900"},{"pdate":"2019-01-04","rdate":"2018-12-31","type":"预升","abs":"预计2018年1-12月归属于上市公司股东的净利润为:24818百万,与上年同期相比变动幅度:7%。","old":"1.3000"}]
近年业绩预告
API地址:https://api.zhituapi.com/hs/gs/yjyg/股票代码?token=token证书
描述:根据《股票列表》得到的股票代码获取上市公司近年来的业绩预告。按公告日期倒序。
更新频率:每日03:30
字段名称 | 数据类型 | 字段说明 |
---|---|---|
pdate | string | 公告日期yyyy-MM-dd |
rdate | string | 报告期yyyy-MM-dd |
type | string | 类型 |
abs | string | 业绩预告摘要 |
old | string | 上年同期每股收益(元) |