开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1397|回复: 9
收起左侧

[其它源码] 本地部署的deepseek,流式输出

[复制链接]

结帖率:100% (47/47)
发表于 2025-2-7 12:30:09 | 显示全部楼层 |阅读模式   江西省南昌市
分享源码
界面截图: -
是否带模块: -
备注说明: -
以下有三个参数
model:模型名称
prompt:询问内容
temperature:严谨与发散程度(0-2),数字越大越发散

[C#] 纯文本查看 复制代码
private void generate(string model, string prompt, double temperature)
{
    using (RestClient client = new RestClient("http://localhost:11434"))
    {
        var request = new RestRequest("/api/generate", Method.Post);

        request.AddHeader("Content-Type", "application/json");

        var body = new
        {
            model, 
            prompt,
            options = new
            {
                temperature
            },
            stream = true
        };

        request.AddStringBody(JsonConvert.SerializeObject(body), DataFormat.None);

        var responseStream = client.DownloadStream(request);

        if (responseStream != null)
        {
            using (var reader = new StreamReader(responseStream))
            {
                string line;
                while ((line = reader.ReadLine()) != null)
                {
                    JObject bite = JObject.Parse(line);
                    bool done = (bool)bite["done"];
                    if (!done)
                    {
                        textBox2.Invoke((MethodInvoker)delegate
                        {
                            var response = (string)bite["response"];
                            textBox2.AppendText(response.Replace("\n", "\r\n"));
                        });
                    }
                    else
                    {
                        long total_duration = (long)bite["total_duration"]; // 生成响应所花费的时间
                        long load_duration = (long)bite["load_duration"]; // 加载模型所花费的时间(纳秒)
                        long prompt_eval_count = (long)bite["prompt_eval_count"]; // 提示中的令牌数
                        long prompt_eval_duration = (long)bite["prompt_eval_duration"]; // 评估提示所花费的时间(纳秒)
                        long eval_count = (long)bite["eval_count"]; // 响应中的令牌数
                        long eval_duration = (long)bite["eval_duration"]; // 生成响应所花费的时间(纳秒)

                        label4.Invoke((MethodInvoker)delegate
                        {
                            label4.Text = $"生成响应所花费的时间:{total_duration / 1e9}s\r\n" +
                                            $"加载模型所花费的时间:{load_duration / 1e9}s\r\n" +
                                            $"提示中的令牌数:{prompt_eval_count}\r\n" +
                                            $"响应中的令牌数:{eval_count}\r\n" +
                                            $"评估提示所花费的时间:{prompt_eval_duration / 1e9}s\r\n" +
                                            $"生成响应所花费的时间:{eval_duration / 1e9}s\r\n";
                        });
                    }
                }
            }
        }
    }
}


不知道model怎么填?
发送请求看看你部署了哪几个模型。


[C#] 纯文本查看 复制代码
using (RestClient client = new RestClient("http://localhost:11434"))
{
    var request = new RestRequest("/api/tags", Method.Get);

    var response = client.Execute(request);

    if (response.IsSuccessful)
    {
        try
        {
            var resp = response.Content.UnescapeUnicode();
            var json = JObject.Parse(resp);
            foreach (JObject array in json["models"])
            {
                var pair = new KeyValuePair<string, string>((string)array["name"], (string)array["size"]);

                comboBox_models.Invoke((MethodInvoker)delegate
                {
                    comboBox_models.Items.Add(pair);
                });
            }
        }
        catch (JsonException ex)
        {
            Console.WriteLine(ex.Message);
        }
    }
}


发表于 2025-2-15 00:09:45 | 显示全部楼层   河南省郑州市
学习了!谢谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (5/5)
发表于 2025-2-13 12:58:11 | 显示全部楼层   安徽省淮南市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)
发表于 2025-2-8 21:11:30 | 显示全部楼层   内蒙古自治区鄂尔多斯市
1111111111111111111
回复 支持 反对

使用道具 举报

结帖率:81% (59/73)

签到天数: 3 天

发表于 2025-2-8 14:02:54 | 显示全部楼层   北京市北京市
大佬新年好~~~
回复 支持 反对

使用道具 举报

结帖率:68% (15/22)

签到天数: 2 天

发表于 2025-2-8 00:46:18 | 显示全部楼层   福建省厦门市
怎么同步显示回复信息?
回复 支持 反对

使用道具 举报

结帖率:80% (8/10)
发表于 2025-2-7 19:22:22 高大上手机用户 | 显示全部楼层   陕西省安康市
部署8b也是卵用没有
回复 支持 反对

使用道具 举报

结帖率:100% (14/14)
发表于 2025-2-7 18:27:57 | 显示全部楼层   广东省江门市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:50% (2/4)

签到天数: 2 天

发表于 2025-2-7 14:42:24 | 显示全部楼层   福建省厦门市
羡慕你们的电脑~我的估计只能部署1.5b那个
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 2 天

发表于 2025-2-7 14:36:29 | 显示全部楼层   辽宁省丹东市
这是大佬
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表