广告位联系
返回顶部
分享到

Python配置同花顺全数据接口教程介绍

python 来源:互联网 作者:秩名 发布时间:2022-01-27 20:10:37 人浏览
摘要

前往:http://quantapi.10jqka.com.cn/?page=home 如果是windows,根据不同用户,可以选择不同的下载。 一、iFinDPy 模块 下载完成后,会出现一个 DataInterface_free_Windows_20210812.7z 的文件,解压到任意文

前往: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。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

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

from iFinDPy import *

from datetime import datetime

import pandas as pd

import time as _time

import json

from threading import Thread,Lock,Semaphore

import requests

sem = 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) + ' ')

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

        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 = 320

pd.options.display.max_columns = None

 

def 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()


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/wowotuo/article/details/122674450
相关文章
  • Python Django教程之实现新闻应用程序

    Python Django教程之实现新闻应用程序
    Django是一个用Python编写的高级框架,它允许我们创建服务器端Web应用程序。在本文中,我们将了解如何使用Django创建新闻应用程序。 我们将
  • 书写Python代码的一种更优雅方式(推荐!)

    书写Python代码的一种更优雅方式(推荐!)
    一些比较熟悉pandas的读者朋友应该经常会使用query()、eval()、pipe()、assign()等pandas的常用方法,书写可读性很高的「链式」数据分析处理代码
  • Python灰度变换中伽马变换分析实现

    Python灰度变换中伽马变换分析实现
    1. 介绍 伽马变换主要目的是对比度拉伸,将图像灰度较低的部分进行修正 伽马变换针对的是对单个像素点的变换,也就是点对点的映射 形
  • 使用OpenCV实现迷宫解密的全过程

    使用OpenCV实现迷宫解密的全过程
    一、你能自己走出迷宫吗? 如下图所示,可以看到是一张较为复杂的迷宫图,相信也有人尝试过自己一点一点的找出口,但我们肉眼来解谜
  • Python中的数据精度问题的介绍

    Python中的数据精度问题的介绍
    一、python运算时精度问题 1.运行时精度问题 在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和
  • Python随机值生成的常用方法

    Python随机值生成的常用方法
    一、随机整数 1.包含上下限:[a, b] 1 2 3 4 import random #1、随机整数:包含上下限:[a, b] for i in range(10): print(random.randint(0,5),end= | ) 查看运行结
  • Python字典高级用法深入分析讲解
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python浅析多态与鸭子类型使用实例
    什么多态:同一事物有多种形态 为何要有多态=》多态会带来什么样的特性,多态性 多态性指的是可以在不考虑对象具体类型的情况下而直
  • Python字典高级用法深入分析介绍
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本

    Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本
    我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计