【AI选股】如何通过python调用通达信-小达实现AI选股(量化又多了一个选股工具,原文Chrome浏览器请改为Edge浏览器)

这篇具有很好参考价值的文章主要介绍了【AI选股】如何通过python调用通达信-小达实现AI选股(量化又多了一个选股工具,原文Chrome浏览器请改为Edge浏览器)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


前言

ChatGPT火遍网络,那么有没有可以不用写公式就可以实现AI选股的方法?答案是有,今天我们就来试试通达信的小达,让小达按我们的要求去进行选股。

使用Chrome浏览器报错的请改为Edge浏览器,或者Firefox浏览器,参考如下文章:
【Python小技巧】browser_cookie3访问Chrome浏览器Cookies文件报错的解决办法_IT里的交易员的博客-CSDN博客


一、通达信-小达是什么?

通达信-小达是一款操作简单,输入检索语句即可实现用户智能选股、资讯检索、答疑解惑等需求的投资系统,让投资成为一句话的事。
小达通过人工智能技术,汇集行情、资讯、数据库以及各大功能组件于一体,具备语义解析、信息聚合以及机器学习在内的多项功能的智能
服务产品,支持自有内容的服务对接。

通达信-小达功能包含:智能选股、股海神搜、全文检索等
官网地址:https://wenda.tdx.com.cn/
【AI选股】如何通过python调用通达信-小达实现AI选股(量化又多了一个选股工具,原文Chrome浏览器请改为Edge浏览器)

二、使用步骤

这里主要是使用requests,系统应该都自带,而且我将其修改成类的方式,调用会更方便。
其实之前有人已经写了代码,我也是参考修改下。只是每次要更新cookie,否则将无法访问,对各位量化朋友不太友好,所以这里攻克了一下,以后就可以方便的使用了。

1. 引入browser_cookie3库

browser_cookie3可以读取电脑浏览器(例如Chrome Firefox Opera Edge Chromium Brave)本身已经缓存的cookie。使用前先安装下,方便后面操作。当然你手动会操作,也可以不用这个库。不过为方便使用,推荐安装,毕竟每天登录手工提取cookie也够麻烦的。

pip install browser-cookie3 

2. 通达信-小达 AI选股源代码

首先是完成注册,请自行搞定。本文同时支持以下两种方法访问。推荐方法2,因为只要电脑用浏览器登录一下即可完成自动访问。

方法1:使用任意浏览器登录https://wenda.tdx.com.cn/,并按F12查看网络,找到Cookie复制后替换这里ASPSessionID后数值即可使用。
xd = TDX_xiaoda(cookie = ‘ASPSessionID=xxxxxxxxxxx’)
【AI选股】如何通过python调用通达信-小达实现AI选股(量化又多了一个选股工具,原文Chrome浏览器请改为Edge浏览器)

方法2:使用Chrome浏览器登录https://wenda.tdx.com.cn/后,无需手工查找Cookie,程序会自动获取ASPSessionID,并实现访问。
# 注意:Chrome浏览器114版无法访问Cookies文件,故修改为edge浏览器。故以上原文请改用微软Edge浏览器登录访问网页。

# -*- coding: utf-8 -*-
'''
通达信-小达
'''
import requests
import browser_cookie3
import pandas as pd
import json,os,random


class TDX_xiaoda:
    '''
    通达信-小达,使用chrome浏览器登录后,此工具可以自动获取ASPSessionID,并实现访问。
    '''
    def __init__(self,cookie=''):
        # 如果类传送Cookie则使用传参
        if cookie=='': 
            self.cookie = self.get_cookie_tdx()
        else:
            self.cookie = cookie

    def set_headers(self):
        # 增加UserAgent,防止被反爬虫拦截
        user_agent_list = ["Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36",
                            "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36",
                            "Mozilla/5.0 (Windows NT 10.0; WOW64) Gecko/20100101 Firefox/61.0",
                            "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.186 Safari/537.36",
                            "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.62 Safari/537.36",
                            "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36",
                            "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)",
                            "Mozilla/5.0 (Macintosh; U; PPC Mac OS X 10.5; en-US; rv:1.9.2.15) Gecko/20110303 Firefox/3.6.15",
                            ]
        headers = {
            'Cookie': self.cookie,
            'User-Agent': random.choice(user_agent_list)}
        return headers

    def _get_cookie_tdx(self):
        # 查找指定域名的指定Cookie值
        cookies = browser_cookie3.edge(domain_name='wenda.tdx.com.cn')# 注意:Chrome浏览器114版无法访问Cookies文件,故修改为edge浏览器,或者改为firefox浏览器。
        for item in cookies:
            if item.name == "ASPSessionID" :
                # print('%s = %s' % (item.name, item.value))
                cookie_tdx = 'ASPSessionID=' + item.value + ';'
                return cookie_tdx

    def get_data_option(self,word='涨停股票'):
        '''
        获取提示参考
        :param word:
        :return:
        '''
        data = [{"op_flag":1,"question":word,"POS":0,"COUNT":10,"RANG":"AG"}]
        url = 'https://wenda.tdx.com.cn/TQL?Entry=NLPSE.QuestionImagine&RI='
        headers = self.set_headers()
        res = requests.post(url=url,data=json.dumps(data),headers=headers)
        res_json = res.json()
        return res_json
        
    def get_word_code(self,name='换手率2.8~15,量比2~20,OBV指标创新高,涨幅2~7,股价2~30'):
        '''
        :param name:
        :return:
        '''
        data = [{"message":name,"TDXID":"","wdbk":"","RANG":"AG"}]
        url = 'https://wenda.tdx.com.cn/TQL?Entry=NLPSE.StockSelect&RI='
        headers = self.set_headers()
        res = requests.post(url=url,headers=headers,data=json.dumps(data))
        res_json = res.json()
        code = res_json[-1][0]
        return code
        
    def get_all_option_data(self):
        '''
        获取全部参考
        :return:
        '''
        url = 'https://wenda.tdx.com.cn/TQL?Entry=NLPSE.SmartQuery&RI='
        headers = self.set_headers()
        data = [{"op_flag":1,"order_field":"","order_flag":1,"cond_json":"","POS":0,"COUNT":-1,"RANG":"AG"}]
        res = requests.post(url=url,headers=headers,data=json.dumps(data))
        res_json = res.json()
        df = pd.DataFrame(res_json)
        df = df.iloc[1:]
        df2 = df.rename(columns=df.iloc[0])
        df3 = df2.iloc[1:]
        return df3
        
    def get_word_result(self,word='今日涨停',try_times = 30):
        '''
        根据关键字分析后获取数据
        :param word:关键字
        :return:字典,包含状态和数据
        '''
        while try_times>0:
            url = 'https://wenda.tdx.com.cn/TQL?Entry=NLPSE.NLPQuery&RI=6BFD'
            code = self.get_word_code(name=word)
            headers = self.set_headers()
            data = [{"nlpse_id":code,"POS":0,"COUNT":100000,"order_field":"","dynamic_order":"","order_flag":"","timestamps":0,"op_flag":1,"screen_type":1,"RANG":"AG"}]
            res = requests.post(url=url,headers=headers,data=json.dumps(data))
            text = res.content.decode('utf-8')
            res_json = json.loads(text)
            if len(res_json[1])<4:
                try_times -= 1
                print('获取信息失败,剩余'+str(try_times)+'次尝试机会,再次尝试连接......')
            else:
                # print(text)
                df = pd.DataFrame(res_json)
                df = df.iloc[1:]
                df2 = df.rename(columns=df.iloc[0])
                df3 = df2.iloc[2:]
                return {
                        "success": True,
                        "df_data":df3.round(3)
                    }
        return {
            "success": False,
            "msg": '获取行情信息结果为None'
        }


# ===============表格美化输出===============
def df_table(df,index):
    import prettytable as pt
    #利用prettytable对输出结果进行美化,index为索引列名:df_table(df,'market')
    tb = pt.PrettyTable()
    # 如果为trade_time为index转换为日期类型,其它不用管。
    if index == "trade_time":
        df = df.set_index(index)
        df.index = pd.DatetimeIndex(df.index)
    # df.reset_index(level=None, drop=True, inplace=True, col_level=0, col_fill='')
    df = df.reset_index(drop = True)
    tb.add_column(index,df.index)#按date排序
    for col in df.columns.values:#df.columns.values的意思是获取列的名称
        # print('col',col)
        # print('df[col]',df[col])
        tb.add_column(col, df[col])
    print(tb)


if __name__=='__main__':
    # 以下两种方法均可以,推荐方法2。注册请自行搞定。
    # 方法1:使用任意浏览器登录https://wenda.tdx.com.cn/,并按F12查看网络,找到Cookie复制后替换这里ASPSessionID后数值即可使用。注意不要带分号。
    # xd = TDX_xiaoda(cookie = 'ASPSessionID=xxxxxxxxxx') 
    # 方法2:使用Chrome浏览器登录https://wenda.tdx.com.cn/后,无需手工查找Cookie,程序会自动获取ASPSessionID,并实现访问。但必须使用Chrome浏览器。
    xd = TDX_xiaoda() 
        
    if 0:
        #可能获取不到
        ret = xd.get_data_option(word='沪深A股,换手率1%~5%')
        print(ret)
        #获取问题转代码
        ret = xd.get_word_code(name='沪深A股,换手率1%~5%')
        print(ret)
        #获取全部的参考,具体看通达信
        ret = xd.get_all_option_data()
        # print(ret)
        df_table(ret,'df')
    
    if 1:
        #获取问题的结果
        words = '沪深A股,周线MACD持续向上,今日涨停' # 连板 3连板 今日涨停 20230201涨停 北向资金 板块 大单抢筹 MACD背离
        ret = xd.get_word_result(word=words)
        if ret['success']:
            df = ret['df_data']
            # print(df)
            df_table(df,'df')
            filename = os.path.dirname(__file__)+'\\'+'通达信-小达选股_'+words+'.xlsx'
            df.to_excel(filename)
            print('选股完成,结果写入:',filename)
            

总结

这次写了通达信的AI选股,之前写过使用同花顺的问财AI选股,下面是传送门。需要的小伙伴自行学习。

【AI选股】如何通过python调用wencai包实现AI选股(小白也能学会)https://blog.csdn.net/popboy29/article/details/126336227

同花顺的问财也很方便,不过每次检索限制了200条。个人看情况调用。通达信目前还未发现限制。另外就是这个不用安装,代码透明,方便调用。

搞了一天,肩膀有些酸痛,写作不易,关键是不停的调试代码,很是费事儿。各位如果觉得有帮助,不妨点个赞再开始调试使用,顺祝大家发财!

同时,这里对通达信及之前写作代码的大虾一并表示感谢!文章来源地址https://www.toymoban.com/news/detail-503621.html

到了这里,关于【AI选股】如何通过python调用通达信-小达实现AI选股(量化又多了一个选股工具,原文Chrome浏览器请改为Edge浏览器)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 使用python进行AI选股之同花顺问财

      通过问财python库,可以输入中文就能获取AI选股结果,而不需要写很多代码来进行股票选取,如上图就是输入中文”均线多头排列的股票”获取的结果。本文主要介绍问财python库的选股功能和使用步骤。 同花顺i问财是同花顺旗下的AI投顾平台,专注于使用AI技术改进财经数

    2024年01月18日
    浏览(119)
  • [Python] 如何通过ctypes库来调用C++ 动态库 DLL?

    ctypes是Python的一个外部库,它提供了一种灵活的方式来调用C语言的动态链接库(DLL)或共享库(SO)。通过ctypes,我们可以在Python中直接调用 C语言编写的函数和变量 ,从而实现跨语言的互操作。 ctypes 它提供了与 C 兼容的数据类型,并允许调用 DLL 或共享库中的函数。可使用该模

    2024年01月19日
    浏览(29)
  • ai智能体如何实现函数调用?我的猜测

    ai智能体,又名ai agent,是一种基于ai大模型推理能力,具有外部感知、工具使用、信息反馈的智能系统。 自从2023年3月autoGPT发布以来,已经诞生了许多ai agent框架。他们大多遵循这个基本的结构: 大部分框架基本都提供了让开发者自定义添加行为与函数调用的方法。openai在

    2024年01月21日
    浏览(25)
  • 如何通过python写接口自动化脚本对一个需要调用第三方支付的报名流程进行测试?

    对于需要调用第三方支付的报名流程进行接口自动化测试,可以通过以下步骤来编写Python代码: 1. 确认API需求 首先,需要确认报名流程的API需求和预期功能。这涉及到对业务需求的理解和API设计的分析。 2. 安装依赖库 在Python程序中,需要安装requests库(用于发送HTTP请求)和

    2024年02月10日
    浏览(54)
  • Python调用Open-AI接口实现ChatGPT

    一、前言 近年来,人工智能技术的广泛应用,为社会带来了自动化和智能化的效率提升。自然语言处理技术的快速发展也提供了更多的人工智能应用场景。本文将介绍如何使用Python编程语言,结合Open-AI接口实现ChatGPT的简单应用。 二、介绍 ChatGPT是一个能够执行在线对话的人

    2024年02月10日
    浏览(39)
  • 【AI】Python调用讯飞星火大模型接口,轻松实现文本生成

    随着chatGPT的出现,通用大模型已经成为了研究的热点,由于众所周知的原因,亚太地区调用经常会被禁,在国内,讯飞星火大模型是一个非常优秀的中文预训练模型。本文将介绍如何使用Python调用讯飞星火大模型接口,实现文本生成等功能。 1. 安装API库 需要安装库,在命令

    2024年02月09日
    浏览(48)
  • 通过python如何实现视频提取音频,并将音频转文本

    大致思路: (1)使用moviepy库中的VideoFileClip类读取视频文件,并将其转换为音频文件; (2)使用pydub库中的splitonsilence函数将音频文件分割成多个音频片段,以便进行语音识别; (3)使用SpeechRecognition库中的Recognizer类进行语音识别,并将识别结果写入文本文件中 注意: 将

    2024年02月05日
    浏览(46)
  • 小市值选股策略代码分享(附python源码)

    小市值选股策略的核心在于通过综合分析公司的基本面、行业定位、财务健康状况以及市场趋势, 来寻找那些被市场低估但具备显著成长潜力的股票,同时也要重视风险管理和投资组合的多样化。   今天来给大家分享下小市值策略代码如下:   以上是一个简洁的小市值策略

    2024年02月05日
    浏览(30)
  • 通过python调用OpenAI的API

    一、需要注册OpenAI账号 这个网上很多教程,随便搜索一大片,只是需要科学上网。。。 二、 获取OpenAI的API密钥 登陆OpenAI的API地址:https://platform.openai.com/  创建API KEY, 创建好的key记得立刻复制出来 ,因为创建完成后无法再次查看   三、安装python安装包openai 安装openai安装包

    2024年02月01日
    浏览(44)
  • 聊聊不同集群的微服务如何通过feign调用

    之前业务部门的某项目微服务调用关系如下图 后因业务改造需要,该项目需要将服务A部署到另外一个集群,但服务A仍然需要能调用到服务B,调用关系如下图 之前调用方式是负责服务B的开发团队提供相应的feign客户端包给到服务A开发团队,服务A开发团队直接将客户端包引入

    2024年02月13日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包