Python如何配置同花顺全数据接口
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要介绍了Python如何配置同花顺全数据接口,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前往:http://quantap
千家信息网最后更新 2025年11月07日Python如何配置同花顺全数据接口
这篇文章主要介绍了Python如何配置同花顺全数据接口,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
前往:http://quantapi.10jqka.com.cn/?page=home
如果是windows,根据不同用户,可以选择不同的下载。
一、iFinDPy 模块
下载完成后,会出现一个DataInterface_free_Windows_20210812.7z的文件,解压到任意文件夹中。打开该文件夹进入Bin文件夹后,再打开Tool文件夹,双击运行SuperCommand.exe,并使用iFinD账号免费登录。
选择python,确定。同时添加路径。
选上。然后重启电脑,相关环境变量设置生效。
现在就可以在python环境中调用iFinDPy了。
二、相关代码
安装iFinDPy后,即可。具体可以参考:http://quantapi.10jqka.com.cn/?page=sample。
# -*- coding: utf-8 -*-from iFinDPy import *from datetime import datetimeimport pandas as pdimport time as _timeimport jsonfrom threading import Thread,Lock,Semaphoreimport requestssem = Semaphore(5) # 此变量用于控制最大并发数dllock = Lock() #此变量用来控制实时行情推送中落数据到本地的锁# 登录函数def thslogindemo(): # 输入用户的帐号和密码 thsLogin = THS_iFinDLogin("数据接口_账号","数据接口_密码") print(thsLogin) if thsLogin != 0: print('登录失败') else: print('登录成功')def datepool_basicdata_demo(): # 通过数据池的板块成分函数和基础数据函数,提取沪深300的全部股票在2020-11-16日的日不复权收盘价 data_hs300 = THS_DP('block', '2020-11-16;001005290', 'date:Y,thscode:Y,security_name:Y') if data_hs300.errorcode != 0: print('error:{}'.format(data_hs300.errmsg)) else: seccode_hs300_list = data_hs300.data['THSCODE'].tolist() data_result = THS_BD(seccode_hs300_list, 'ths_close_price_stock', '2020-11-16,100') if data_result.errorcode != 0: print('error:{}'.format(data_result.errmsg)) else: data_df = data_result.data print(data_df)def datapool_realtime_demo(): # 通过数据池的板块成分函数和实时行情函数,提取上证50的全部股票的最新价数据,并将其导出为csv文件 today_str = datetime.today().strftime('%Y-%m-%d') print('today:{}'.format(today_str)) data_sz50 = THS_DP('block', '{};001005260'.format(today_str), 'date:Y,thscode:Y,security_name:Y') if data_sz50.errorcode != 0: print('error:{}'.format(data_sz50.errmsg)) else: seccode_sz50_list = data_sz50.data['THSCODE'].tolist() data_result = THS_RQ(seccode_sz50_list,'latest') if data_result.errorcode != 0: print('error:{}'.format(data_result.errmsg)) else: data_df = data_result.data print(data_df) data_df.to_csv('realtimedata_{}.csv'.format(today_str))def iwencai_demo(): # 演示如何通过不消耗流量的自然语言语句调用常用数据 print('输出资金流向数据') data_wencai_zjlx = THS_WC('主力资金流向', 'stock') if data_wencai_zjlx.errorcode != 0: print('error:{}'.format(data_wencai_zjlx.errmsg)) else: print(data_wencai_zjlx.data) print('输出股性评分数据') data_wencai_xny = THS_WC('股性评分', 'stock') if data_wencai_xny.errorcode != 0: print('error:{}'.format(data_wencai_xny.errmsg)) else: print(data_wencai_xny.data)def dlwork(tick_data): # 本函数为实时行情订阅新启线程的任务函数 dllock.acquire() with open('dlwork.txt', 'a') as f: for stock_data in tick_data['tables']: if 'time' in stock_data: timestr = _time.strftime('%Y-%m-%d %H:%M:%S', _time.localtime(stock_data['time'][0])) print(timestr) f.write(timestr + str(stock_data) + '\n') else: pass dllock.release()def work(codestr,lock,indilist): sem.acquire() stockdata = THS_HF(codestr, ';'.join(indilist),'','2020-08-11 09:15:00', '2020-08-11 15:30:00','format:json') if stockdata.errorcode != 0: print('error:{}'.format(stockdata.errmsg)) sem.release() else: print(stockdata.data) lock.acquire() with open('test1.txt', 'a') as f: f.write(str(stockdata.data) + '\n') lock.release() sem.release()def multiThread_demo(): # 本函数为通过高频序列函数,演示如何使用多线程加速数据提取的示例,本例中通过将所有A股分100组,最大线程数量sem进行提取 # 用户可以根据自身场景进行修改 today_str = datetime.today().strftime('%Y-%m-%d') print('today:{}'.format(today_str)) data_alla = THS_DP('block', '{};001005010'.format(today_str), 'date:Y,thscode:Y,security_name:Y') if data_alla.errorcode != 0: print('error:{}'.format(data_alla.errmsg)) else: stock_list = data_alla.data['THSCODE'].tolist() indi_list = ['close', 'high', 'low', 'volume'] lock = Lock() btime = datetime.now() l = [] for eachlist in [stock_list[i:i + int(len(stock_list) / 10)] for i in range(0, len(stock_list), int(len(stock_list) / 10))]: nowstr = ','.join(eachlist) p = Thread(target=work, args=(nowstr, lock, indi_list)) l.append(p) for p in l: p.start() for p in l: p.join() etime = datetime.now() print(etime-btime)pd.options.display.width = 320pd.options.display.max_columns = Nonedef reportDownload(): df = THS_ReportQuery('300033.SZ','beginrDate:2021-08-01;endrDate:2021-08-31;reportType:901','reportDate:Y,thscode:Y,secName:Y,ctime:Y,reportTitle:Y,pdfURL:Y,seq:Y').data print(df) for i in range(len(df)): pdfName = df.iloc[i,4]+str(df.iloc[i,6])+'.pdf' pdfURL = df.iloc[i,5] r = requests.get(pdfURL) with open(pdfName,'wb+') as f: f.write(r.content)def main(): # 本脚本为数据接口通用场景的实例,可以通过取消注释下列示例函数来观察效果 # 登录函数 thslogindemo() # 通过数据池的板块成分函数和基础数据函数,提取沪深300的全部股票在2020-11-16日的日不复权收盘价 # datepool_basicdata_demo() #通过数据池的板块成分函数和实时行情函数,提取上证50的全部股票的最新价数据,并将其导出为csv文件 # datapool_realtime_demo() # 演示如何通过不消耗流量的自然语言语句调用常用数据 # iwencai_demo() # 本函数为通过高频序列函数,演示如何使用多线程加速数据提取的示例,本例中通过将所有A股分100组,最大线程数量sem进行提取 # multiThread_demo() # 本函数演示如何使用公告函数提取满足条件的公告,并下载其pdf # reportDownload()if __name__ == '__main__': main()感谢你能够认真阅读完这篇文章,希望小编分享的"Python如何配置同花顺全数据接口"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
数据
函数
文件
接口
线程
演示
登录
实时
实时行情
成分
文件夹
板块
篇文章
股票
行情
最大
变量
用户
示例
同花
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
公安机关网络安全条例
数据库中如何将时间减去2年
数据库恢复技术题目
全国 省市 数据库
鸿蒙软件开发工具
软件开发测试报告工具
怎么自己做服务器我的世界网易版
互联网科技有限公司 介绍
北京安卓软件开发哪里好
小学网络安全知识网络竞赛
网络安全技术形考作业4
钢琴家下载软件开发
sql测试数据库脚本编写
无法更改服务器配置
恒银网络技术有限公司
深圳市蜂巢网络技术
服务器租用带宽标准
服务器地址发送文件怎么弄
医院网络安全岗位培训
那面设立网络安全日
数据库下载后如何分享到微信
hp服务器初始管理地址
华勤通讯应用软件开发工程师
石景山cmmi软件开发认证
全国 省市 数据库
达梦数据库客户端工具下载
网络安全项目建设方案
东营联想服务器代理零售
数据库查第5到10条数据
计算机网络技术ppt