仿Manus一

复制
┌───────────────┐       ┌─────────────┐
│   主界面UI    │◄─────►│ 会话管理模块 │
└───────┬───────┘       └──────┬──────┘│                      │▼                      ▼
┌───────────────┐       ┌─────────────┐
│ API通信模块   │       │ 文件存储模块 │
└───────┬───────┘       └───────┬─────┘│                       │▼                       ▼
┌───────────────────────────────┐
│       SiliconFlow API         │
└───────────────────────────────┘用户操作流程:
1. 新建会话 → 生成sessionID → 创建空todu文件
2. 输入问题 → 调用API → 解析响应 → 更新todu
3. 切换会话 → 加载对应todu文件 → 刷新界面
二、核心模块分工
1.1.界面交互模块
- 负责控件事件处理
- 管理界面状态刷新
- 提供用户输入验证
1.2.会话管理模块
- 维护会话列表和当前会话状态
- 处理会话切换时的数据加载/保存
- 生成唯一sessionID
1.3.API通信模块
- 构造符合规范的请求报文
- 处理API响应和错误码
- 结果解析和数据结构转换
1.4.文件存储模块
- 管理todu目录的文件存储
- 实现JSON格式的序列化/反序列化
- 文件变更监控和自动保存
三、主要类实现代码(精简版)
  1. 1.会话管理核心类
csharp复制
public class SessionManager
{private string _currentSessionId;private readonly string _workspacePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "todu");public void InitWorkspace(){if (!Directory.Exists(_workspacePath))Directory.CreateDirectory(_workspacePath);}public string CreateNewSession(){var sessionId = Guid.NewGuid().ToString("N");File.WriteAllText(GetSessionFilePath(sessionId), "[]");return sessionId;}public void SwitchSession(string sessionId){_currentSessionId = sessionId;if (!File.Exists(GetSessionFilePath(sessionId)))throw new FileNotFoundException("Session file missing");}public List<TodoItem> GetCurrentTodos(){return JsonConvert.DeserializeObject<List<TodoItem>>(File.ReadAllText(GetSessionFilePath(_currentSessionId)));}private string GetSessionFilePath(string sessionId) => Path.Combine(_workspacePath, $"{sessionId}.json");
}

2.API通信处理类

csharp复制
public class TodoApiClient
{private const string ApiEndpoint = "https://api.siliconflow.cn/v1/chat/completions";public async Task<List<TodoItem>> GenerateTodosAsync(string question){using var client = new HttpClient();client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", "[YOUR_API_KEY]");var request = new{model = "deepseek-ai/DeepSeek-V3",messages = new[] {new { role = "user", content = $"请根据以下问题生成规范的待办事项列表:{question}。按JSON数组格式返回" }},response_format = new { type = "json_object" }};var response = await client.PostAsync(ApiEndpoint, new StringContent(JsonConvert.SerializeObject(request), Encoding.UTF8, "application/json"));var responseObj = JObject.Parse(await response.Content.ReadAsStringAsync());return ParseTodoJson(responseObj["choices"][0]["message"]["content"].ToString());}private List<TodoItem> ParseTodoJson(string json){// 示例响应格式:{ "todos": [{...}] }return JObject.Parse(json)["todos"]?.Select(t => new TodoItem {Id = Guid.NewGuid(),Content = t["content"].ToString(),Created = DateTime.Now}).ToList() ?? new List<TodoItem>();}
}

3.文件存储服务

csharp复制
public class TodoFileManager
{private FileSystemWatcher _watcher;public void SetupFileWatcher(Action<string> onChange){_watcher = new FileSystemWatcher{Path = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "todu"),Filter = "*.json",NotifyFilter = NotifyFilters.LastWrite};_watcher.Changed += (s, e) => onChange(e.Name.Replace(".json", ""));_watcher.EnableRaisingEvents = true;}public void SaveTodos(string sessionId, List<TodoItem> todos){var json = JsonConvert.SerializeObject(todos, Formatting.Indented);File.WriteAllText(GetFilePath(sessionId), json, Encoding.UTF8);}private string GetFilePath(string sessionId) => Path.Combine("todu", $"{sessionId}.json");
}

4.窗口界面关键代码(Windows Forms)

csharp复制
public partial class MainForm : Form
{private SessionManager _sessionManager = new SessionManager();private TodoApiClient _apiClient = new TodoApiClient();private BindingList<TodoItem> _currentTodos = new BindingList<TodoItem>();public MainForm(){InitializeComponent();_sessionManager.InitWorkspace();lstSessions.DisplayMember = "Key";lstSessions.ValueMember = "Value";todoListBox.DataSource = _currentTodos;todoListBox.DisplayMember = "Content";}// 新建会话按钮private void btnNewSession_Click(object sender, EventArgs e){var sessionId = _sessionManager.CreateNewSession();lstSessions.Items.Add(new KeyValuePair<string, string>($"会话 {lstSessions.Items.Count+1}", sessionId));}// 发送提问按钮private async void btnSend_Click(object sender, EventArgs e){var todos = await _apiClient.GenerateTodosAsync(txtInput.Text);_currentTodos.Clear();foreach(var item in todos)_currentTodos.Add(item);_sessionManager.SaveCurrentTodos(_currentTodos.ToList());}// 切换会话选择private void lstSessions_SelectedIndexChanged(object sender, EventArgs e){if(lstSessions.SelectedItem is KeyValuePair<string, string> selected){_sessionManager.SwitchSession(selected.Value);_currentTodos = new BindingList<TodoItem>(_sessionManager.GetCurrentTodos());todoListBox.DataSource = _currentTodos;}}
}

5.扩展功能建议

csharp复制
// 增加会话元数据存储
public class SessionMetadata
{public string SessionId { get; set; }public string Title { get; set; }public DateTime LastModified { get; set; }
}// 在SessionManager中添加
public void SaveSessionMetadata(SessionMetadata meta)
{var path = Path.Combine(_workspacePath, "_sessions.json");var list = File.Exists(path) ? JsonConvert.DeserializeObject<List<SessionMetadata>>(File.ReadAllText(path)) : new List<SessionMetadata>();if(list.Any(m => m.SessionId == meta.SessionId))list.RemoveAll(m => m.SessionId == meta.SessionId);list.Add(meta);File.WriteAllText(path, JsonConvert.SerializeObject(list));
}
TODO项状态管理扩展
csharp复制
public class TodoItem
{public Guid Id { get; set; }public string Content { get; set; }public bool IsCompleted { get; set; }public DateTime Created { get; set; }public DateTime? CompletedDate { get; set; }
}// 在界面中添加状态切换
private void todoListBox_MouseDoubleClick(object sender, MouseEventArgs e)
{if(todoListBox.SelectedItem is TodoItem item){item.IsCompleted = !item.IsCompleted;item.CompletedDate = item.IsCompleted ? DateTime.Now : null;_sessionManager.SaveCurrentTodos(_currentTodos.ToList());todoListBox.Refresh();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/73120.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VS Code C++ 开发环境配置

VS Code 是当前非常流行的开发工具. 本文讲述如何配置 VS Code 作为 C开发环境. 本文将按照如下步骤来介绍如何配置 VS Code 作为 C开发环境. 安装编译器安装插件配置工作区 第一个步骤的具体操作会因为系统不同或者方案不同而有不同的选择. 环境要求 首先需要立即 VS Code…

Flutter 学习之旅 之 flutter 不使用插件,实现简单带加载动画的 LoadingToast 功能

Flutter 学习之旅 之 flutter 不使用插件&#xff0c;实现简单带加载动画的 LoadingToast 功能 目录 Flutter 学习之旅 之 flutter 不使用插件&#xff0c;实现简单带加载动画的 LoadingToast 功能 一、简单介绍 二、LoadingToast 三、简单案例实现 四、关键代码 一、简单…

Spring (八)AOP-切面编程的使用

目录 实现步骤&#xff1a; 1 导入AOP依赖 2 编写切面Aspect 3 编写通知方法 4 指定切入点表达式 5 测试AOP动态织入 图示&#xff1a; 一 实现步骤&#xff1a; 1 导入AOP依赖 <!-- Spring Boot AOP依赖 --><dependency><groupId>org.springframewor…

开源数字人模型Heygem

一、Heygem是什么 Heygem 是硅基智能推出的开源数字人模型&#xff0c;专为 Windows 系统设计。基于先进的AI技术&#xff0c;仅需1秒视频或1张照片&#xff0c;能在30秒内完成数字人形象和声音克隆&#xff0c;在60秒内合成4K超高清视频。Heygem支持多语言输出、多表情动作&a…

uniapp开通开屏广告后动态开启或关闭开屏广告

近期使用uniapp开发的APP有uniad的广告对接&#xff0c;并且要求会员用户不显示包含开屏广告在内的广告&#xff0c;除开屏广告外的广告都可以通过uniapp广告组件控制是否显示 因uniad的开屏广告无需代码开发&#xff0c;经过uniad客服指点可在App.vue中的onLaunch生命周期中执…

神经网络为什么要用 ReLU 增加非线性?

在神经网络中使用 ReLU&#xff08;Rectified Linear Unit&#xff09; 作为激活函数的主要目的是引入非线性&#xff0c;这是神经网络能够学习复杂模式和解决非线性问题的关键。 1. 为什么需要非线性&#xff1f; 1.1 线性模型的局限性 如果神经网络只使用线性激活函数&…

使用SSH密钥连接本地git 和 github

目录 配置本地SSH&#xff0c;添加到github首先查看本地是否有SSH密钥生成SSH密钥&#xff0c;和邮箱绑定将 SSH 密钥添加到 ssh-agent&#xff1a;显示本地公钥*把下面这一串生成的公钥存到github上* 验证SSH配置是否成功终端跳转到本地仓库把http协议改为SSH&#xff08;如果…

关于AI数据分析可行性的初步评估

一、结论&#xff1a;可在部分环节嵌入&#xff0c;无法直接处理大量数据 1.非本地部署的AI应用处理非机密文件没问题&#xff0c;内部文件要注意数据安全风险。 2.AI&#xff08;指高规格大模型&#xff09;十分适合探索性研究分析&#xff0c;对复杂报告无法全流程执行&…

矩阵分析-浅要理解(深度学习方向)

梯度分析与最优化 在深度学习的任务中&#xff0c;我们所期望的是训练一个神经网络&#xff0c;使得预测结果与真实标签之间的误差最小化&#xff0c;这可以近似看作是一个提供梯度下降等优化找到全局最优解的凸优化问题。 奇异值分解 在信息工程领域&#xff0c;对数据处理的…

使用DeepSeek+蓝耘快速设计网页简易版《我的世界》小游戏

前言&#xff1a;如今&#xff0c;借助先进的人工智能模型与便捷的云平台&#xff0c;即便是新手开发者&#xff0c;也能开启创意游戏的设计之旅。DeepSeek 作为前沿的人工智能模型&#xff0c;具备强大的功能与潜力&#xff0c;而蓝耘智算云平台则为其提供了稳定高效的运行环境…

固定表头、首列 —— uniapp、vue 项目

项目实地&#xff1a;也可以在 【微信小程序】搜索体验&#xff1a;xny.handbook 另一个体验项目&#xff1a;官网 一、效果展示 二、代码展示 &#xff08;1&#xff09;html 部分 <view class"table"><view class"tr"><view class&quo…

【学习笔记】Numpy和Tensor的区别

1. NumPy 和 PyTorch Tensor 的格式对比 NumPy 使用的是 numpy.ndarray&#xff0c;而 PyTorch 使用的是 torch.Tensor&#xff0c;两者的格式在数据存储和计算方式上有所不同。 NumPy (numpy.ndarray) import numpy as np array np.array([[1.0, 2.0, 3.0], [4.0, 5.0, 6.…

每天一道算法题【蓝桥杯】【在排序数组中查找元素的第一个位置和最后一个位置】

思路 本题为查找左边界和右边界的标准模型 查找左边界 int left 0, right nums.size() - 1, mid 0; //查找左边界 while (left < right) { mid left (right - left) / 2; if (nums[mid] < target) left mid 1; else right mid; } 查找右边界 int left 0, r…

Python数据分析之机器学习基础

Python 数据分析重点知识点 本系列不同其他的知识点讲解&#xff0c;力求通过例子让新同学学习用法&#xff0c;帮助老同学快速回忆知识点 可视化系列&#xff1a; Python基础数据分析工具数据处理与分析数据可视化机器学习基础 五、机器学习基础 了解机器学习概念、分类及…

我与DeepSeek读《大型网站技术架构》(10)- 维基百科的高性能架构设计分析

目录 网站整体架构核心组件请求处理流程图关键环节说明 性能优化策略前端优化&#xff1a;拦截 80% 以上请求服务端优化&#xff1a;高性能 PHP 集群后端优化&#xff1a;存储与缓存极致设计Memcached 持久化连接 性能优化策略对比表 网站整体架构 核心组件 Wikipedia 的架构…

Excel多级联动下拉菜单设置

1.问题描述 现有数据表如下图所示&#xff1a; 该表中包括省、市、县三级目录。 现要将其整理成数据表模板&#xff0c;如下图所示&#xff1a; 要求制作成下拉菜单的形式&#xff0c;且每一级目录的下拉菜单列表要根据上一级目录的内容来确定。 如上图所示&#xff0c;只有…

智驾技术全链条解析

智驾技术全链条解析&#xff08;2025年最新版&#xff09; 智驾技术涵盖从环境感知到车辆控制的完整闭环&#xff0c;涉及硬件、算法、数据与系统集成等多个领域。以下结合行业最新进展&#xff08;截至2025年3月&#xff09;进行深度拆解&#xff1a; 一、感知技术&#xff1…

SpringMVC执行的流程

SpringMVC 基于 MVC 架构模式&#xff0c;核心流程时前端控制室 DispathcherServlet 统一调度&#xff0c;通过组件协作完成 http 的请求与响应。 对于 dispatchServlet 作为前端请求的控制器&#xff0c;全局的访问点&#xff0c;首先将根据 URL 调用 HandlerMapping 获取 Han…

Linux学习(十五)(故障排除(ICMP,Ping,Traceroute,网络统计,数据包分析))

故障排除是任何 Linux 用户或管理员的基本技能。这涉及识别和解决 Linux 系统中的问题。这些问题的范围包括常见的系统错误、硬件或软件问题、网络连接问题以及系统资源的管理。Linux 中的故障排除过程通常涉及使用命令行工具、检查系统和应用程序日志文件、了解系统进程&#…

存储过程和自定义函数在银行信贷业务中的应用(oracle)

数据校验和清洗 例如&#xff0c;检查客户的年龄是否在合理范围内&#xff0c;贷款金额是否符合规定的上下限等。 对于不符合规则的数据&#xff0c;可以进行清洗和修正。比如&#xff0c;将空值替换为默认值&#xff0c;或者对错误的数据进行纠正。 CREATE OR REPLACE PROC…