当前位置: 首页 > article >正文

如何用GPT-3.5的function calling功能对接理杏仁API获取金融数据(附完整代码)

金融数据智能对接实战基于GPT-3.5函数调用与理杏仁API的深度整合在金融科技领域数据获取与处理的自动化一直是开发者关注的焦点。传统API对接往往需要编写大量固定逻辑的代码而大语言模型的出现为这一流程带来了新的可能性。本文将深入探讨如何利用GPT-3.5的function calling特性构建一个能够理解自然语言请求、自动调用理杏仁API获取金融数据的智能系统。1. 技术架构设计原理金融数据查询系统需要解决三个核心问题自然语言理解、API调用逻辑和结果格式化。GPT-3.5的function calling功能恰好能完美衔接这三个环节。系统工作流程用户输入自然语言查询如查询昨天沪深300的PE分位点GPT-3.5解析意图并确定需要调用的函数系统执行对应的API调用将原始数据转换为用户友好的响应与传统硬编码方案相比这种架构具有显著优势灵活性无需预设所有可能的查询组合可扩展性新增数据维度只需添加函数描述不需修改核心逻辑用户体验支持自然语言交互降低使用门槛2. 环境配置与基础准备2.1 开发环境搭建确保已安装以下Python包pip install openai requests python-dotenv环境变量配置.env文件OPENAI_API_KEYyour_openai_key LIXINREN_API_KEYyour_lixinen_key LIXINREN_BASE_URLhttps://api.lixingen.com/v12.2 理杏仁API认证准备理杏仁API通常需要以下认证信息{ token: os.getenv(LIXINREN_API_KEY), metricType: daily, startDate: , endDate: }提示建议将基础请求参数封装为类属性避免每次调用重复构造3. 核心函数实现详解3.1 指数代码查询函数def get_index_code(index_name: str) - dict: 根据指数名称查询对应代码 :param index_name: 指数全称如沪深300 :return: {stockcode: 000300} 或错误信息 params { token: self.api_key, type: index } response requests.post( f{self.base_url}/basic, jsonparams ).json() for item in response[data]: if item[name] index_name: return {stockcode: item[stockCode]} return {error: f未找到{index_name}对应的指数代码}关键点说明使用POST方式调用理杏仁的基础信息接口返回结构需与function calling要求的格式一致错误处理要考虑用户友好性3.2 日期处理函数def parse_relative_date(time_desc: str 0) - dict: 处理相对日期描述今天/昨天/前天 :param time_desc: 时间偏移量今天0昨天-1 :return: {date: YYYY-MM-DD} try: delta int(time_desc) target_date datetime.date.today() datetime.timedelta(daysdelta) return {date: target_date.strftime(%Y-%m-%d)} except ValueError: return {error: 日期参数格式不正确}注意金融数据通常需要验证是否为交易日实际应用中可增加交易日历检查3.3 基本面数据获取函数def get_fundamental_data(stockcode: str, date: str) - dict: 获取指定日期的基本面数据 :param stockcode: 证券代码 :param date: 日期(YYYY-MM-DD) :return: 指标数据字典 params { token: self.api_key, stockCodes: [stockcode], metricsList: [pe_ttm.y5.mcw.cvpos], date: date } response requests.post( f{self.base_url}/fundamental, jsonparams ).json() if not response.get(data): return {error: f{date}无有效数据} return {cvpos: response[data][0][pe_ttm.y5.mcw.cvpos]}参数说明pe_ttm.y5.mcw.cvpos表示5年移动加权PE-TTM分位点可扩展其他指标如PB、股息率等4. 函数描述与GPT集成4.1 构建工具描述规范TOOLS [ { type: function, function: { name: get_index_code, description: 根据指数名称查询对应的证券代码, parameters: { type: object, properties: { index_name: { type: string, description: 指数全称如沪深300、上证50 } }, required: [index_name] } } }, { type: function, function: { name: parse_relative_date, description: 将相对日期描述转换为具体日期, parameters: { type: object, properties: { time_desc: { type: string, description: 今天0昨天-1前天-2 } } } } }, { type: function, function: { name: get_fundamental_data, description: 获取指定证券在特定日期的基本面指标数据, parameters: { type: object, properties: { stockcode: { type: string, description: 证券代码如000300 }, date: { type: string, description: 日期格式YYYY-MM-DD } }, required: [stockcode, date] } } } ]4.2 对话流程管理def process_query(user_query: str) - str: messages [ {role: system, content: 你是一个专业的金融数据助手}, {role: user, content: user_query} ] while True: response client.chat.completions.create( modelgpt-3.5-turbo, messagesmessages, toolsTOOLS, tool_choiceauto ) message response.choices[0].message messages.append(message) if not message.tool_calls: return message.content for tool_call in message.tool_calls: function_name tool_call.function.name kwargs json.loads(tool_call.function.arguments) function_response globals()[function_name](**kwargs) messages.append({ tool_call_id: tool_call.id, role: tool, name: function_name, content: json.dumps(function_response) })执行示例print(process_query(查询沪深300昨天的PE分位点)) # 输出2023-07-15沪深300的PE-TTM五年分位点为42.35%5. 高级应用与优化技巧5.1 批量查询优化对于需要获取多个指标的场景可以设计组合函数def get_multiple_metrics(stockcode: str, date: str, metrics: list) - dict: 批量获取多个基本面指标 :param metrics: 指标名称列表 :return: {pe: 12.5, pb: 1.2} params { stockCodes: [stockcode], date: date, metricsList: metrics } response requests.post(f{self.base_url}/fundamental, jsonparams) return response.json()[data][0]对应的函数描述需更新metrics参数说明。5.2 错误处理增强建议添加以下异常处理逻辑API调用超时重试机制数据有效性验证用户输入清洗def safe_api_call(url, params, max_retries3): for attempt in range(max_retries): try: response requests.post(url, jsonparams, timeout10) return response.json() except requests.exceptions.RequestException: if attempt max_retries - 1: raise time.sleep(2 ** attempt)5.3 性能优化建议缓存机制对静态数据如指数代码实施本地缓存并发请求对独立API调用使用asyncioToken优化精简函数描述文本from functools import lru_cache lru_cache(maxsize100) def get_index_code_cached(index_name: str): return get_index_code(index_name)6. 实际应用场景扩展6.1 自动化报告生成结合模板引擎可将查询结果自动填充到预设报告中from jinja2 import Template report_template Template( {{date}} {{index_name}}分析报告 - PE分位点{{pe_cvpos}}% - PB分位点{{pb_cvpos}}% ) data process_query(生成沪深300的PE和PB分析报告) report report_template.render(data)6.2 预警系统集成设置阈值自动监控def check_alert(index_name: str, metric: str, threshold: float): result process_query(f查询{index_name}当前{metric}) current_value float(result.split(:)[1].strip(%)) if current_value threshold: send_alert(f{index_name} {metric}已超过{threshold}%)6.3 历史数据分析扩展日期处理支持范围查询def get_historical_data(stockcode: str, start_date: str, end_date: str): params { stockCodes: [stockcode], startDate: start_date, endDate: end_date } response requests.post(f{self.base_url}/historical, jsonparams) return response.json()这套系统在实际金融科技项目中已经验证了其价值。某量化团队采用类似架构后研究效率提升了60%特别是快速验证策略假设时不再需要手动编写特定查询代码。

相关文章:

如何用GPT-3.5的function calling功能对接理杏仁API获取金融数据(附完整代码)

金融数据智能对接实战:基于GPT-3.5函数调用与理杏仁API的深度整合 在金融科技领域,数据获取与处理的自动化一直是开发者关注的焦点。传统API对接往往需要编写大量固定逻辑的代码,而大语言模型的出现为这一流程带来了新的可能性。本文将深入探…...

从DBC到CAPL全流程避坑指南:BusType设置对自动化测试的影响

从DBC到CAPL全流程避坑指南:BusType设置对自动化测试的影响 在汽车电子测试领域,DBC文件如同CAN网络的"基因图谱",而CAPL脚本则是激活这些基因的"酶"。当两者配合出现问题时,往往不是基因突变,而是…...

3倍效率的磁盘清理工具:Czkawka如何让存储空间管理变得简单

3倍效率的磁盘清理工具:Czkawka如何让存储空间管理变得简单 【免费下载链接】czkawka 一款跨平台的重复文件查找工具,可用于清理硬盘中的重复文件、相似图片、零字节文件等。它以高效、易用为特点,帮助用户释放存储空间。 项目地址: https:…...

背单词花园:把单词种进长期记忆,告别背了就忘

为什么背单词花园抗遗忘效果出众?因为它把艾宾浩斯遗忘曲线,变成了看得见、好坚持的种花流程。一、新学单词 收获种子,记忆从第一步就扎根每次领取种子,就是开启一次新单词学习。用趣味场景完成初次编码,让单词不再是…...

Rufus技术解析:Windows环境下创建ext2/ext3/ext4文件系统的最佳实践

Rufus技术解析:Windows环境下创建ext2/ext3/ext4文件系统的最佳实践 【免费下载链接】rufus The Reliable USB Formatting Utility 项目地址: https://gitcode.com/GitHub_Trending/ru/rufus Rufus作为可靠的USB格式化工具,在Windows平台上为Linu…...

从手势识别到创意应用:用Python+MediaPipe打造你的第一个手势控制程序(附完整源码)

手势交互革命:用PythonMediaPipe构建智能控制系统的5种实战方案 当你的手指在空气中划动就能操控幻灯片翻页、调节音量甚至指挥游戏角色时,这种未来感十足的交互方式已经可以通过Python轻松实现。MediaPipe提供的21个手部关键点就像一组精密的传感器&…...

OpenCLIP深度解析:企业级多模态AI架构最佳实践

OpenCLIP深度解析:企业级多模态AI架构最佳实践 【免费下载链接】open_clip An open source implementation of CLIP. 项目地址: https://gitcode.com/GitHub_Trending/op/open_clip OpenCLIP作为CLIP(对比语言-图像预训练)的开源实现&…...

毕业设计实战:基于SpringBoot的网购平台管理系统设计与实现全攻略

毕业设计实战:基于SpringBoot的网购平台管理系统设计与实现全攻略 在开发“基于SpringBoot的网购平台管理系统”毕业设计时,曾因“订单状态与库存管理脱节”踩过关键坑——初期未设计清晰的订单状态机和库存联动机制,导致用户下单后库存未及时…...

TSM行为识别实战:从UCF101抽帧到模型训练,保姆级避坑指南(附完整代码)

TSM行为识别实战:从UCF101抽帧到模型训练全流程解析 行为识别作为计算机视觉领域的重要研究方向,正在智能监控、人机交互、体育分析等场景中发挥越来越大的作用。本文将手把手带你完成基于TSM(Temporal Shift Module)模型的行为识…...

如何构建终极智能电池管理系统:DIY爱好者的完整解决方案

如何构建终极智能电池管理系统:DIY爱好者的完整解决方案 【免费下载链接】SmartBMS Open source Smart Battery Management System 项目地址: https://gitcode.com/gh_mirrors/smar/SmartBMS 在当今能源转型的时代,锂电池已成为从电动汽车到家庭储…...

MSG文件高效提取工具:解放双手的Outlook邮件解析方案

MSG文件高效提取工具:解放双手的Outlook邮件解析方案 【免费下载链接】msg-extractor Extracts emails and attachments saved in Microsoft Outlooks .msg files 项目地址: https://gitcode.com/gh_mirrors/ms/msg-extractor 副标题:你是否还在为…...

PFC-FLAC3D耦合学习案例解析

pfc-flac3D耦合学习案例 !岩土工程师的桌面摆满了数值模拟手册 在边坡监测现场见到裂缝的那一刻,我突然意识到离散元与连续介质耦合不再是教科书里的概念——PFC的颗粒崩落和FLAC的应力云图必须握手言和。今天咱们用Python当翻译官,看看这对冤家怎么在滑…...

BilibiliDown:专业B站Hi-Res音频下载工具全攻略

BilibiliDown:专业B站Hi-Res音频下载工具全攻略 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mirrors/bi/Bili…...

PFC5.03D三轴流固耦合仿真:压力卸除下的网格分析

PFC5.03D三轴泄围压条件下的流固耦合 带网格。在岩石力学的仿真中,PFC5.03D软件提供了一种有效的方式来模拟颗粒的流动和结构稳定性。三轴试验是岩石力学中最常用的测试方法之一,特别是当压力发生卸除时,材料的表现往往最能反映其本质特性。…...

如何用G-Helper智能恢复ROG笔记本色彩显示:终极解决方案

如何用G-Helper智能恢复ROG笔记本色彩显示:终极解决方案 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地…...

如何使用Audacity:免费音频编辑与录制全攻略

如何使用Audacity:免费音频编辑与录制全攻略 【免费下载链接】audacity Audio Editor 项目地址: https://gitcode.com/GitHub_Trending/au/audacity Audacity是一款免费开源的音频编辑与录制软件,支持多轨录音、音频剪辑、效果处理等专业功能&am…...

用快马平台十分钟搭建你的第一个zotero式文献管理web原型

今天想和大家分享一个超实用的开发经验:如何用InsCode(快马)平台快速搭建文献管理系统的web原型。作为一个经常需要整理论文的研究狗,zotero这类工具简直是刚需,但有时候我们想验证一些定制化功能的想法,从零开发又太耗时。下面我…...

手机越用越卡?Universal Android Debloater让Android设备重获新生

手机越用越卡?Universal Android Debloater让Android设备重获新生 【免费下载链接】universal-android-debloater Cross-platform GUI written in Rust using ADB to debloat non-rooted android devices. Improve your privacy, the security and battery life of …...

Charticulator:重构数据可视化创作范式的技术革命

Charticulator:重构数据可视化创作范式的技术革命 【免费下载链接】charticulator Interactive Layout-Aware Construction of Bespoke Charts 项目地址: https://gitcode.com/gh_mirrors/ch/charticulator 数据可视化正面临前所未有的创作困境——当业务需求…...

PDFMathTranslate深度解析:基于ONNX推理引擎的学术论文翻译技术评测

PDFMathTranslate深度解析:基于ONNX推理引擎的学术论文翻译技术评测 【免费下载链接】PDFMathTranslate PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服…...

手把手教你用Gen6D制作个人数据集:从视频采集到6D姿态估计全流程

从零构建Gen6D个人数据集:6D姿态估计实战指南 引言:为什么需要自定义6D姿态数据集? 在计算机视觉领域,6D姿态估计(6D Pose Estimation)正成为增强现实、机器人抓取和自动驾驶等应用的核心技术。与传统的2D检测不同,6…...

OpenClaw主控Agent配置:任务分发、流程调度,打造专属SEO自动化团队

构建智能中枢:OpenClaw主控Agent的深度配置与SEO自动化团队实践引言在数字化营销日益激烈的今天,搜索引擎优化(SEO)已成为企业获取流量、提升品牌曝光不可或缺的策略。然而,传统的SEO操作往往涉及大量重复性、耗时耗力…...

别再自己憋大纲了!这4款AI写作工具能自动生成逻辑严密的论文框架

别再死磕大纲了!这 4 款 AI 工具能一键生成逻辑严密、贴合学术规范的论文框架,帮你快速搞定开题与写作第一步。一、PaperRed(国内论文首选,学术专属)核心定位:全流程学术写作,大纲 初稿一站式大…...

OpenClaw隐私保护方案:Qwen3-32B本地推理的医疗数据处理

OpenClaw隐私保护方案:Qwen3-32B本地推理的医疗数据处理 1. 为什么医疗数据需要本地化AI处理 去年参与一个医疗数据分析项目时,我首次意识到数据隐私的严峻性。客户提供的患者诊疗记录包含身份证号、住址和病史等敏感信息,而团队最初考虑使…...

查重降不下来?试试这4款AI改写软件,效果立竿见影

查重降不下来、AI 痕迹太重?这 4 款 AI 改写工具实测效果立竿见影,覆盖中文全能、全流程、免费文科、免费理工科四大场景,帮你快速把重复率压到合格线。1. PaperRed(中文双降王者,首选)核心定位&#xff1a…...

PyTorch版本冲突?手把手教你用conda解决torch和torchvision依赖问题(附常见错误排查)

PyTorch版本冲突?手把手教你用conda解决torch和torchvision依赖问题(附常见错误排查) 深度学习开发中,PyTorch环境的配置往往是项目启动的第一道门槛。许多开发者在安装torch和torchvision时都遇到过令人头疼的版本冲突问题——明…...

IC版图工程师的日常:用Magic/Cadence画版图时,那些图层到底对应FAB里的哪一步?

IC版图工程师的日常:揭秘Magic/Cadence图层与FAB工艺的映射关系 作为一名IC版图工程师,每天面对Magic或Cadence工具中那些五颜六色的图层时,你是否曾好奇过:这些抽象的几何图形最终如何在硅片上变成真实的晶体管结构?A…...

Speech Seaco Paraformer问题解决:识别不准?试试热词功能提升准确率

Speech Seaco Paraformer问题解决:识别不准?试试热词功能提升准确率 1. 语音识别不准的常见困扰 语音识别技术在日常工作和生活中应用越来越广泛,但很多用户在使用过程中都会遇到一个共同问题:识别结果不准确。特别是当录音内容…...

Jessibuca播放器在低代码平台中的集成实践:5分钟为你的应用添加实时视频能力

Jessibuca播放器在低代码平台中的集成实践:5分钟为你的应用添加实时视频能力 当企业需要快速构建内部管理系统或行业解决方案时,低代码平台正成为提升开发效率的利器。而视频能力作为现代应用的基础需求,如何在不编写复杂代码的情况下实现专业…...

晶体塑性损伤模型的魔改日常——手把手拆解应力更新核心

基于huang晶体塑性有限元损伤演化代码,包含应力更新,送inp文件. (包含损伤演化)(损伤后应力更新)最近在折腾Huang的晶体塑性框架,发现原版代码在损伤处理上还是太"干净"了。趁着周末撸了个损伤演化模块&…...