使用django调用deepseek api,搭建ai网站
一、deepseek简介
DeepSeek是一家人工智能公司,专注于开发先进的人工智能模型和技术。以下是关于DeepSeek的一些详细介绍:
1.公司背景
DeepSeek由杭州深度求索人工智能基础技术研究有限公司开发,致力于通过创新的技术和算法,推动人工智能领域的发展。
2.技术与模型
- DeepSeek-V3:这是DeepSeek开发的一个大型语言模型,具有超过600B的参数,在多项性能指标上与国际顶尖模型相当。
- DeepSeek-R1:这是DeepSeek的第一代推理模型,通过大规模强化学习(RL)进行训练,展示出了在推理任务上的优异性能。
- DeepSeek-R1-Distill:这些是从DeepSeek-R1中蒸馏出的小模型,具有更好的性能和效率,适合在资源受限的环境中使用。
3.应用领域
- 自然语言处理:DeepSeek的模型在文本生成、知识问答、推理等任务中表现出色,能够为用户提供高质量的语言交互服务。
- 智能助手:DeepSeek开发了AI智能助手,可用于搜索、写作、阅读、解题、翻译等多种任务,帮助用户提高效率。
4.优势与特点
- 成本优势:DeepSeek的模型训练成本低,调用接口成本也较低,具有较高的性价比。
- 中文处理能力强:对中文语法、成语、文化背景理解更深入,在中文文本生成、摘要、情感分析等任务中表现自然。
- 开源优势:DeepSeek-R1模型权重和技术报告开源,便于开发者二次开发和创新。
5.产品与服务
- DeepSeek API:提供与OpenAI兼容的API,方便开发者将DeepSeek的模型集成到自己的应用中。
- DeepSeek App:提供AI智能助手应用,可在App Store上下载,支持多种功能,如智能对话、搜索、写作等。
二、获取apikey
deepseek官方的api暂时无法充值,我使用的是阿里云的百炼平台的deepseek v1模型,阿里云百炼平台注册送百万token,可以白嫖。打开百炼控制台,开通服务,随便选择一个模型,点击右上角的“查看我的apikey”,获取apikey。

三、创建django项目,并startapp
使用django创建一个新的项目,python manage.py startapp chat新建app作为主要代码文件夹。
四、编写代码
chat\views.py
from django.shortcuts import render
from openai import OpenAI
import os
from django.conf import settingsdef get_ai_response(messages):
client = OpenAI(
api_key="xxx",//填写apikey
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)try:completion = client.chat.completions.create(model="qwen2.5-14b-instruct-1m",messages=messages)return {'content': completion.choices[0].message.content,'reasoning': getattr(completion.choices[0].message, 'reasoning_content', '')}
except Exception as e:return {'content': f"发生错误:{str(e)}",'reasoning': ''}def chat_view(request):
if 'messages' not in request.session:
request.session['messages'] = []if request.method == 'POST':user_message = request.POST.get('message', '')if user_message:request.session['messages'].append({'role': 'user', 'content': user_message})response = get_ai_response(request.session['messages'])request.session['messages'].append({'role': 'assistant','content': response['content'],'reasoning': response['reasoning']})request.session.modified = Truereturn render(request, 'chat.html', {'messages': request.session['messages']
})
要将api_key="xxx"中xxx替换为自己的apikey。
urls.py
from django.contrib import admin
from django.urls import path
from chat import viewsurlpatterns = [path('admin/', admin.site.urls),path('', views.chat_view, name='chat'),
]
前端代码
<!DOCTYPE html>
<html>
<head><title>AI对话助手(Markdown支持版)</title><!-- Markdown 渲染依赖 --><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/github-markdown-css@5.2.0/github-markdown.min.css"><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/styles/github-dark.min.css"><style>:root {--user-color: #1a73e8;--assistant-color: #0b8043;}body {max-width: 800px;margin: 0 auto;padding: 20px;font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;background-color: #f8f9fa;}.chat-container {background: white;border-radius: 12px;box-shadow: 0 2px 8px rgba(0,0,0,0.1);padding: 20px;margin-bottom: 20px;}.message {margin: 15px 0;padding: 12px 16px;border-radius: 8px;}.user-message {background-color: #e8f0fe;border: 1px solid var(--user-color);margin-left: 30px;}.assistant-message {background-color: #e6f4ea;border: 1px solid var(--assistant-color);margin-right: 30px;}.role-label {font-weight: 500;margin-bottom: 8px;display: flex;align-items: center;gap: 8px;}.role-label::before {content: '';display: inline-block;width: 12px;height: 12px;border-radius: 50%;}.user-message .role-label::before {background: var(--user-color);}.assistant-message .role-label::before {background: var(--assistant-color);}form {display: flex;gap: 10px;margin-top: 20px;}input[type="text"] {flex: 1;padding: 12px;border: 1px solid #ddd;border-radius: 8px;font-size: 16px;}button {padding: 12px 24px;background-color: var(--user-color);color: white;border: none;border-radius: 8px;cursor: pointer;transition: background 0.2s;}button:hover {background-color: #1557b0;}.markdown-body pre {padding: 16px;border-radius: 8px;overflow-x: auto;}.reasoning-box {margin-top: 12px;padding: 12px;background: #fff8e5;border-left: 4px solid #ffd700;border-radius: 4px;}</style>
</head>
<body><div class="chat-container"><h1 style="color: var(--user-color); text-align: center;">AI对话助手</h1><div class="messages">{% for message in messages %}<div class="message {% if message.role == 'user' %}user-message{% else %}assistant-message{% endif %}"><div class="role-label">{% if message.role == 'user' %}👤 用户{% else %}🤖 助手{% endif %}</div><!-- Markdown 内容容器 --><div class="markdown-body"data-markdown="{{ message.content|escape }}"data-raw="{{ message.content|escape }}">{{ message.content|safe }}</div>{% if message.reasoning %}<div class="reasoning-box"><div class="reasoning-label">💡 思考过程</div><div class="markdown-body"data-markdown="{{ message.reasoning|escape }}"data-raw="{{ message.reasoning|escape }}">{{ message.reasoning|safe }}</div></div>{% endif %}</div>{% endfor %}</div><form method="post">{% csrf_token %}<input type="text" name="message" placeholder="请输入您的问题..." required autofocus><button type="submit">发送</button></form></div><!-- 依赖库 --><script src="https://cdn.jsdelivr.net/npm/marked@12.0.0/lib/marked.min.js"></script><script src="https://cdn.jsdelivr.net/npm/dompurify@3.0.5/dist/purify.min.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/highlight.min.js"></script><script>// 初始化配置marked.setOptions({breaks: true,highlight: (code, lang) => {const language = hljs.getLanguage(lang) ? lang : 'plaintext';return hljs.highlight(code, { language }).value;}});// Markdown 渲染函数const renderMarkdown = () => {document.querySelectorAll('.markdown-body').forEach(container => {try {// 优先使用 data-markdown 属性const raw = container.dataset.markdown || container.dataset.raw;const clean = DOMPurify.sanitize(raw, {ALLOWED_TAGS: ['b', 'i', 'em', 'strong', 'code', 'pre', 'blockquote','ul', 'ol', 'li', 'h1', 'h2', 'h3', 'a', 'p', 'br', 'hr'],ALLOWED_ATTR: ['href', 'target']});container.innerHTML = marked.parse(clean);} catch (e) {console.error('Markdown渲染失败:', e);container.innerHTML = container.dataset.raw;}});// 触发代码高亮hljs.highlightAll();};// 确保依赖加载完成后执行const checkDependencies = () => {if (window.marked && window.DOMPurify && window.hljs) {renderMarkdown();} else {setTimeout(checkDependencies, 100);}};// 启动渲染流程document.addEventListener('DOMContentLoaded', checkDependencies);</script>
</body>
</html>
迁移数据库
python manage.py makemigrations
python manage.py migrate
五、效果展示

六、将模型切换为deepseek
切换模型只要修改model="qwen2.5-14b-instruct-1m"为deepseek.
相关文章:
使用django调用deepseek api,搭建ai网站
一、deepseek简介 DeepSeek是一家人工智能公司,专注于开发先进的人工智能模型和技术。以下是关于DeepSeek的一些详细介绍: 1.公司背景 DeepSeek由杭州深度求索人工智能基础技术研究有限公司开发,致力于通过创新的技术和算法,推…...
YOLOv12 ——基于卷积神经网络的快速推理速度与注意力机制带来的增强性能结合
概述 实时目标检测对于许多实际应用来说已经变得至关重要,而Ultralytics公司开发的YOLO(You Only Look Once,只看一次)系列一直是最先进的模型系列,在速度和准确性之间提供了稳健的平衡。注意力机制的低效阻碍了它们在…...
两台互通的服务器使用Docker部署一主两从MySQL8.0.35
文章目录 1. 使用Docker Overlay网络(需Swarm模式)在服务器1(172.25.0.19)上:在服务器2(172.25.0.20)上:创建 overlay 网络(172.25.0.19): 2. 部署…...
Java23种设计模式案例
目录 一、概述 二、创建型模式 (Creational Patterns) 单例模式 (Singleton Pattern) 工厂方法模式 (Factory Method Pattern) 抽象工厂模式 (Abstract Factory Pattern) 建造者模式 (Builder Pattern) 原型模式 (Prototype Pattern) 三、结构型模式 (Structu…...
stm32hal库寻迹+蓝牙智能车(STM32F103C8T6)
简介: 这个小车的芯片是STM32F103C8T6,其他的芯片也可以照猫画虎,基本配置差不多,要注意的就是,管脚复用,管脚的特殊功能,(这点不用担心,hal库每个管脚的功能都会给你罗列,很方便的.)由于我做的比较简单,只是用到了几个简单外设.主要是由带霍尔编码器电机的车模,电机…...
JavaScript知识点4
1.解释一下这段JavaScript代码 var fruits ["Apple", "Orange", "Apple", "Mango"]; var a fruits.indexOf("Apple",-1); console.log("index"a); 输出的a值为-1,indexOf的第二个参数是-1…...
形式化数学编程在AI医疗中的探索路径分析
一、引言 1.1 研究背景与意义 在数字化时代,形式化数学编程和 AI 形式化医疗作为前沿领域,正逐渐改变着我们的生活和医疗模式。形式化数学编程是一种运用数学逻辑和严格的形式化语言来描述和验证程序的技术,它通过数学的精确性和逻辑性,确保程序的正确性和可靠性。在软件…...
QT 引入Quazip和Zlib源码工程到项目中,无需编译成库,跨平台,加密压缩,带有压缩进度
前言 最近在做项目时遇到一个需求,需要将升级的文件压缩成zip,再进行传输; 通过网络调研,有许多方式可以实现,例如QT私有模块的ZipReader、QZipWriter;或者第三方库zlib或者libzip或者quazip等࿱…...
Ubuntu 安装 Nginx并配置反向代理
Ubuntu版本:Ubuntu 24.04.2 LTS 一、安装Nginx 更新系统软件包 安装前需确保系统处于最新状态,避免依赖冲突 sudo apt update && sudo apt upgrade -y 安装Nginx主程序 Ubuntu官方仓库已包含稳定版Nginx,直接安装即可 sudo…...
GitHub SSH连接问题解决指南
🔍 GitHub SSH连接问题解决指南 问题描述 遇到错误:ssh: connect to host github.com port 22: Connection refused 说明您的网络环境无法访问GitHub的SSH端口22,常见原因: 防火墙/网络运营商限制(国内常见…...
C++ 跨平台的 GetCurrentThreadId() 获取当前线程ID实现
支持:C11 及早前标准库版本,而无需使用:std::this_thread::get_id()。 支持:NDK/ANDROID、Windows、Linux、MacOS X 等多个操作系统平台。 int64_t GetCurrentThreadId() noexcept { #if defined(_WIN32) || defined(_WIN64)retu…...
钉钉MAKE AI生态大会思考
1. 核心特性 1.1 底层模型开放 除原有模型通义千问外,新接入猎户星空、智普、MinMax、月之暗面、百川智能、零一万物。 1.2 AI搜索 AI搜索贯通企业和个人散落在各地的知识(聊天记录、文档、会议、日程、知识库、项目等),通过大模型对知识逻辑化,直接生成搜索的答案,并…...
SQL笔记#复杂查询
一、视图 1、视图和表 使用试图时会执行SELECT语句并创建一张临时表。视图中保存的是SELECT语句;表中保存的是实际数据。 2、创建视图的方法 CREATE VIEW 视图名称(<视图列名1>,<视图列名2>,……) AS <SELECT语句> CREATE VIEW ProductSum (prod…...
【Linux】基于UDP/TCP套接字编程与守护进程
目录 一、网路套接字编程 (一)基础概念 1、源IP地址与目的IP地址 2、端口号 3、TCP与UDP 4、网络字节序 (二)套接字编程接口 1、socket 常见API 2、sockaddr结构 (三)UDP套接字 1、UDP服务器创建…...
springboot 引入前端
前端 打包 npm run build vue.config.js 文件 publicPath 默认建议保持 / publicPath: ‘/’ 后端 目录 粘贴下面目录之一: src/main/resources/static/ src/main/resources/public/ 补充(用的少) server:servlet:context-path: /thirdAdm…...
RTSP/Onvif安防平台EasyNVR接入EasyNVS显示服务缺失的原因与解决方案
EasyNVS云管理平台具备强大的汇聚与管理功能,支持EasyGBS、EasyNVR等平台的接入,能够将接入的视频资源进行统一输出,提供远程可视化运维等管理功能,特别适合解决设备现场没有固定公网IP但仍需在公网直播的需求。 在某次用户现场部…...
算法系列之回溯算法
在计算机科学领域,算法是解决问题的核心。回溯算法作为一种经典的算法设计技巧,以其试错和回退的思想,在解决许多复杂问题时展现出强大的能力。本文将深入探讨回溯算法,包括其核心概念、实现步骤、代码示例以及适用场景࿰…...
Uniapp 小程序接口封装与使用
深入理解 Uniapp 小程序接口封装与使用 在 Uniapp 小程序开发中,接口请求是获取和交互数据的关键部分。合理地封装接口不仅能提高代码的可维护性,还能增强项目的健壮性。今天,我们就来详细探讨一下如何在 Uniapp 中进行接口封装、引入以及使…...
Harmony开发笔记(未完成)
一、感想 作为一名拥有11年经验的Android开发者,我亲历了Android从高速发展到如今面临“僧多粥少”的过程。技术的世界瞬息万变,没有一种技术能够让人依赖一辈子。去年初,我自学了鸿蒙系统,并顺利通过了鸿蒙官方的初级和高级认。…...
观成科技:海莲花“PerfSpyRAT”木马加密通信分析
1.概述 在2024年9月中旬至10月,东南亚APT组织“海莲花”通过GitHub发布开源安全工具项目,针对网络安全人员发起了定向攻击。通过对相关攻击活动进行分析,可以将其与一些海莲花的样本关联起来。这些样本的通信数据结构与海莲花此前使用的攻击…...
QT桌面应用开发:构建本地化的StructBERT文本查重客户端
QT桌面应用开发:构建本地化的StructBERT文本查重客户端 最近在整理一些文档和报告时,发现了一个挺头疼的问题:不同时期写的材料,或者不同同事提交的内容,经常会有一些段落或句子高度相似。手动去比对,不仅…...
StarUML 6.0.1 永久授权与汉化一体化解决方案(含自动补丁工具)
1. StarUML 6.0.1 永久授权与汉化方案概述 StarUML作为一款轻量级的UML建模工具,在6.0.1版本中引入了更完善的类型支持和性能优化。但对于国内用户而言,官方高昂的订阅费用和纯英文界面始终是两大使用门槛。本文将介绍一种通过Python脚本实现的一体化解决…...
Windows热键冲突快速排查指南:Hotkey Detective实战手册
Windows热键冲突快速排查指南:Hotkey Detective实战手册 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否…...
【AI基建团队紧急通告】:未部署动态采样+语义标注的日志系统,正 silently 丢失83%的幻觉告警信号
第一章:大模型工程化日志与可观测性方案 2026奇点智能技术大会(https://ml-summit.org) 大模型服务在生产环境中面临高并发、长推理链路、多阶段缓存与异构硬件调度等复杂性,传统单体应用的日志范式已无法满足可观测性需求。需构建覆盖输入请求、token…...
COMSOL几何建模避坑指南:从二维草图到三维模型的完整参数化流程
COMSOL几何建模避坑指南:从二维草图到三维模型的完整参数化流程 几何建模是COMSOL仿真分析的基础环节,一个优秀的参数化模型不仅能提升工作效率,更能为后续的多物理场耦合分析奠定坚实基础。本文将系统梳理从二维草图到三维成型的完整工作流&…...
探索三种Navicat试用期重置方案:轻松解锁Mac版数据库管理工具
探索三种Navicat试用期重置方案:轻松解锁Mac版数据库管理工具 【免费下载链接】navicat_reset_mac navicat mac版无限重置试用期脚本 Navicat Mac Version Unlimited Trial Reset Script 项目地址: https://gitcode.com/gh_mirrors/na/navicat_reset_mac 当N…...
Redis命令处理机制源码探究粗
一、项目背景与核心价值 1. 解决的核心痛点 Navicat的数据库连接密码并非明文存储,而是通过AES算法加密后写入.ncx格式的XML配置文件中。一旦用户忘记密码,常规方式只能重新配置连接,效率极低。本项目只作为学习研究使用,不做其他…...
2026艺考志愿填报深度解析:一线实战过来人分享核心技巧
宝子们,艺考志愿填报可是个技术活,稍有不慎就可能与理想院校失之交臂!别慌,优志愿来帮你。下面就来看看优志愿在艺考志愿填报中的核心优势。优志愿艺考填报之AI精准赋能优志愿融合前沿AI技术与独创6大核心算法,基于百亿…...
5分钟掌握Steam Economy Enhancer:提升交易效率300%的终极神器
5分钟掌握Steam Economy Enhancer:提升交易效率300%的终极神器 【免费下载链接】Steam-Economy-Enhancer 中文版:Enhances the Steam Inventory and Steam Market. 项目地址: https://gitcode.com/gh_mirrors/ste/Steam-Economy-Enhancer 还在为S…...
彻底告别Windows Defender烦恼:开源控制工具让你的电脑真正属于你
彻底告别Windows Defender烦恼:开源控制工具让你的电脑真正属于你 【免费下载链接】defender-control An open-source windows defender manager. Now you can disable windows defender permanently. 项目地址: https://gitcode.com/gh_mirrors/de/defender-con…...
