python通过curl实现访问deepseek的API

2025-05-14 14:50

本文主要是介绍python通过curl实现访问deepseek的API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编...

API申请和充值

下面是deepeek的API网站

https://platform.deepseek.com/

进去先注册,是不是手机账号密码都不重要,都一样,完事充值打米,主要是打米后左侧API Keys里面创建一个API Keys,注意自己手抄一个Key,那个你自己完了也打不开而是一堆******,记不住只能重新生成

本地curl访问代码脚本

部分参数意义和选项在代码里标注了

import subprocess
import json
import os

def call_deepseek_api(prompt,
    api_key="sk-0d83************f3a3461486",
    model="deepseek-chat",
    temperature=0.7,
    max_tokens=1000
    ):
    """
    使用cURL调用DeepSeek API
    
    参数:
    - prompt: 提示文本
    - api_key: DeepSeek API密钥,如果未提供则从环境变量获取
    - model: 要使用的模型名称
        通过指定 model='deepseek-chat' 即可调用 DeepSeek-V3。
        通过指定 model='deepseek-reasoner',即可调用 DeepSeek-R1。
    - temperature: 控制随机性的温度参数(随机性,越低越选择概率高的答案,最高1,最低0,0.7时均衡,0.2时死板,1时灵活)
    - max_tokens: 生成的最大token数(计费是通过token,模型的分词器(Tokenizer)决定,粗略的说,1 个单词 ≈ 1.3 个 Token,1 个汉字 ≈ 1~1.5 个 Token,单次费用=输入token*0.0001+输出token*0.0003    
    返回:
    - API响应的JSON解析结果
    """
    # 如果未提供API密钥,则从环境变量获取
    if api_key is None:
        api_key = os.environ.get("DEEPSEEK_API_KEY")
    
    if not api_key:
        raise ValueError("需要提供DeepSeek API密钥")
    
    # 构建API请求的JSON数据
    request_data = {
        "model": model,
        "messages": [{"role": "user", "content": prompt}],
        "temperaphpture": temperature,
        "max_tokens": max_tokens,
        "stream":False
    }
    
    # 构建cURL命令
    #这里可能存在一个问题,访问地址可能是"https://api.deepseek.com/chat/completions"
    curl_cmd = [
        "curl",
        "-X", "POST",
        "https://api.deepseek.com/v1/chat/completions",
        "-H", f"Authorization: Bearer {api_key}",
        "-H", "Content-Type: application/json",
        "-d", json.dumps(request_data)
    ]
    
    try:
        # 执行cURL命令
        result = jssubprocess.run(
            curl_cmd,
            capture_output=True,
            text=True,
            encoding='utf-php8', 
            check=True
        )
        
        # 解析JSON响应
        response = json.loads(result.stdout)
        return response
    
    except subprocess.CalledProcessError as e:
        print(f"API请求失败: {e.stderr}")
        raise
    except json.JSONDecodeError:
        print(f"无法解析API响应: {result.stdout}")
        raise

# 使用示例
if __name__ == "__main__":
    # 方式1: 通过环境变量设置API密钥
    # os.environ["DEEPSEEK_API_KEY"] = "your_api_key_here"
    
    # 方式2: 直接在函数调用中提供API密钥
    api_key = "sk-0d8*******f3a3461486"
    
    # 调用API
    try:
        response = call_deepseek_api(
            prompt="你好,请介绍一下你自己",
            api_key=api_key
        )
        
        # 打印API返回的内容
        if "choices" in response and len(response["choices"]) > 0:
            message = response["choices"][0]["message"]["content"]
            print("API响应:")
            print(message)
        else:
            print("API返回格式异常:", responsChina编程e)
    
    except Exception as e:
        print(f"发生错误: {e}")

这里是上面代码尝试跑起来的结果

到此这篇关于python通过curl实现访问deepseek的API的文章就介绍到这了,更多相关python访问deepseek API内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览www.chinasem.cn下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于python通过curl实现访问deepseek的API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154617

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详