c#中利用Tu Share獲取股票交易信息
一、什么是Tu Share
Tushare是一個(gè)免費(fèi)、開源的python財(cái)經(jīng)數(shù)據(jù)接口包。主要實(shí)現(xiàn)對(duì)股票等金融數(shù)據(jù)從數(shù)據(jù)采集、清洗加工到數(shù)據(jù)存儲(chǔ)的過程,用戶可以免費(fèi)(部分?jǐn)?shù)據(jù)的下載有積分限制)的通過它提供的財(cái)經(jīng)接口獲取股票交易、期貨等財(cái)經(jīng)信息,功能非常強(qiáng)大。該接口和直接到各財(cái)經(jīng)網(wǎng)站爬數(shù)據(jù)相比,最大的優(yōu)勢(shì)就是快,去傳統(tǒng)財(cái)經(jīng)網(wǎng)站爬數(shù)據(jù),好多關(guān)鍵性的股票信息只能一只股一只股爬,而Tu Share的API,一個(gè)調(diào)用可以獲得一天的全部數(shù)據(jù),速度差了好幾個(gè)數(shù)量級(jí)。另外一方面各財(cái)經(jīng)網(wǎng)站的接口的API沒有對(duì)外文檔化,隨時(shí)可能變化,而Tu Share的API有正式的文檔化相對(duì)比較穩(wěn)定。
二、如何注冊(cè)
該網(wǎng)站使用積分制來(lái)控制數(shù)據(jù)的訪問權(quán)限,如果想要訪問數(shù)據(jù),先要到下面這個(gè)網(wǎng)址完成注冊(cè),https://tushare.pro/register。注冊(cè)完成后,可以需要到個(gè)人主頁(yè)中拷貝Token,這個(gè)Token會(huì)在以后的訪問中用到,步驟如下
1、登錄成功后,點(diǎn)擊右上角->個(gè)人主頁(yè)

2、 在“用戶中心”中點(diǎn)擊“接口TOKEN”

3、 可以點(diǎn)擊右側(cè)復(fù)制按鈕復(fù)制token

三、Http API說明
Tushare HTTP數(shù)據(jù)獲取的方式,采用了post的機(jī)制,通過提交JSON body參數(shù),就可以獲得您想要的數(shù)據(jù)。具體參數(shù)說明如下:
輸入?yún)?shù)
api_name:接口名稱,比如stock_basic
token :用戶唯一標(biāo)識(shí),可通過登錄pro網(wǎng)站獲取
params:接口參數(shù),如daily接口中start_date和end_date
fields:字段列表,用于接口獲取指定的字段,以逗號(hào)分隔,如"open,high,low,close"
輸出參數(shù)
code: 接口返回碼,2002表示權(quán)限問題。
msg:錯(cuò)誤信息,比如“系統(tǒng)內(nèi)部錯(cuò)誤”,“沒有權(quán)限”等
data:數(shù)據(jù),data里包含fields和items字段,分別為字段和數(shù)據(jù)內(nèi)容
四、c#(.net core)實(shí)現(xiàn)
1、在Visual Studio中安裝下面幾個(gè)包:Microsoft.Extensions.Http、Newtonsoft.Json
2、封裝方法,實(shí)現(xiàn)對(duì)REST web service的調(diào)用
public interface IHttpClientUtility
{
string HttpClientPost(string url, object datajson);
}
public class HttpClientUtility : IHttpClientUtility
{
public HttpClientUtility()
{
}
public string HttpClientPost(string url, object datajson)
{
using (HttpClient httpClient = new HttpClient()) //http對(duì)象
{
httpClient.DefaultRequestHeaders.Accept.Clear();
httpClient.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
httpClient.Timeout = new TimeSpan(0, 0, 5);
//轉(zhuǎn)為鏈接需要的格式
HttpContent httpContent = new JsonContent(datajson);
//請(qǐng)求
HttpResponseMessage response = httpClient.PostAsync(url, httpContent).Result;
if (response.IsSuccessStatusCode)
{
Task<string> t = response.Content.ReadAsStringAsync();
return t.Result;
}
throw new Exception("調(diào)用失敗");
}
}
}
public class JsonContent : StringContent
{
public JsonContent(object value)
: base(JsonConvert.SerializeObject(value), Encoding.UTF8,
"application/json")
{
}
public JsonContent(object value, string mediaType)
: base(JsonConvert.SerializeObject(value), Encoding.UTF8, mediaType)
{
}
}
3、封裝對(duì)Tu Share API的調(diào)用
public class TuShareUtility
{
private IHttpClientUtility _httpClientUtility;
private string _url = "http://api.waditu.com/";
public TuShareUtility(IHttpClientUtility httpClientUtility)
{
_httpClientUtility = httpClientUtility;
}
/// <summary>
/// 調(diào)用TuShare API
/// </summary>
/// <param name="apiName"></param>
/// <param name="parmaMap"></param>
/// <param name="fields"></param>
/// <returns></returns>
public DataTable GetData(string apiName,Dictionary<string,string> parmaMap,params string[] fields)
{
var tuShareParamObj=new TuShareParamObj(){ ApiName = apiName ,Params = parmaMap,Fields = string.Join(",",fields)};
//做Http調(diào)用
var result=_httpClientUtility.HttpClientPost(_url, tuShareParamObj);
//將返回結(jié)果序列化成對(duì)象
var desResult=JsonConvert.DeserializeObject<TuShareResult>(result);
//如果調(diào)用失敗,拋出異常
if(!string.IsNullOrEmpty(desResult.Msg))
throw new Exception(desResult.Msg);
//返回結(jié)果分成兩部分,一部分是列頭信息,另一部分是數(shù)據(jù)本身,用這兩部分?jǐn)?shù)據(jù)可以構(gòu)建DataTable
DataTable dt = new DataTable();
foreach (var dataField in desResult.Data.Fields)
{
dt.Columns.Add(dataField);
}
foreach (var dataItemRow in desResult.Data.Items)
{
var newdr=dt.NewRow();
for (int i=0;i< dataItemRow.Length;i++)
{
newdr[i] = dataItemRow[i];
}
dt.Rows.Add(newdr);
}
return dt;
}
private class TuShareParamObj
{
[JsonProperty("api_name")]
public string ApiName { get; set; }
[JsonProperty("token")]
public string Token { get; } = "****************";//你的Token
[JsonProperty("params")]
public Dictionary<string, string> Params { get; set; }
[JsonProperty("fields")]
public string Fields { get; set; }
}
private class TuShareData
{
[JsonProperty("fields")]
public string[] Fields { get; set; }
[JsonProperty("items")]
public string[][] Items { get; set; }
}
private class TuShareResult
{
[JsonProperty("code")]
public string Code { get; set; }
[JsonProperty("msg")]
public string Msg { get; set; }
[JsonProperty("data")]
public TuShareData Data { get; set; }
}
}
4、調(diào)用示例
獲得日線行情,整個(gè)過程1秒左右,返回6月24日,股票相關(guān)交易信息,代碼如下,(該網(wǎng)站的其它接口定義可以到https://tushare.pro/document/2查看)
var tuShareUtility=new TuShareUtility();
Dictionary<string, string> p = new Dictionary<string, string>();
p["trade_date"] = "20200624";
var table = tuShareUtility.GetData("daily", p, "");
返回如下結(jié)果

返回字段說明
| 名稱 | 類型 | 描述 |
|---|---|---|
| ts_code | str | 股票代碼 |
| trade_date | str | 交易日期 |
| open | float | 開盤價(jià) |
| high | float | 最高價(jià) |
| low | float | 最低價(jià) |
| close | float | 收盤價(jià) |
| pre_close | float | 昨收價(jià) |
| change | float | 漲跌額 |
| pct_chg | float | 漲跌幅 (未復(fù)權(quán),如果是復(fù)權(quán)請(qǐng)用 通用行情接口 ) |
| vol | float | 成交量 (手) |
| amount | float | 成交額 (千元) |
總結(jié)
到此這篇關(guān)于c#中利用Tu Share獲取股票交易信息的文章就介紹到這了,更多相關(guān)c#獲取股票交易信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于C#?實(shí)現(xiàn)劉謙春晚魔術(shù)(示例代碼)
劉謙春晚魔術(shù)是一個(gè)讓人嘆為觀止的魔術(shù)表演,其中涉及到了數(shù)學(xué)、編程和創(chuàng)意的結(jié)合,看了春晚魔術(shù)的朋友們,是不是好奇春晚劉謙的魔術(shù)是怎么變的,本文分享C#?實(shí)現(xiàn)劉謙春晚魔術(shù)示例代碼,一起看看吧2024-02-02
C# 撒列實(shí)現(xiàn)關(guān)鍵字過濾的實(shí)例
C# 撒列實(shí)現(xiàn)關(guān)鍵字過濾的實(shí)例,需要的朋友可以參考一下2013-04-04

