From 32737f2bab875c55b8ad4cbbf477d907674bc0d4 Mon Sep 17 00:00:00 2001
From: TevinClaw <510129976@qq.com>
Date: Tue, 17 Mar 2026 14:50:46 +0800
Subject: [PATCH] 修复:补回MEMORY.md被删除内容,限制技能只修改指定区块
---
workspace/MEMORY.md | 37 +++++++-
workspace/skills/memory-md-learning/scripts/learning.py | 93 ++++++++++++++---------
workspace/skills/memory-md-hot/scripts/daily_maintenance.py | 56 ++++++--------
3 files changed, 111 insertions(+), 75 deletions(-)
diff --git a/workspace/MEMORY.md b/workspace/MEMORY.md
index 9cfa7f5..0ef2866 100644
--- a/workspace/MEMORY.md
+++ b/workspace/MEMORY.md
@@ -9,10 +9,9 @@
> 记录具有全局长期性影响的重要决策和事件。
> 添加重要事件时会告知用户。
-> 记录具有全局长期性影响的重要决策和事件。
-> 添加重要事件时会告知用户。
-> 记录具有全局长期性影响的重要决策和事件。
-> 添加重要事件时会告知用户。
+- 2026-03-14 --:-- | 创建AI早报定时任务(每日9点飞书发送) | 定时任务,自动化
+- 2026-03-16 --:-- | 安装LanceDB-Pro向量记忆系统 | 向量数据库,RAG
+- 2026-03-16 --:-- | 移除三层记忆架构,采用热记忆模式 | 架构重构,记忆系统
---
@@ -25,7 +24,33 @@
- 2026-03-17 --:-- | 暂无记录 | --
+### 2026-03-16
+
+- 2026-03-16 17:00 | 移除三层记忆架构,清理相关技能和文件 | 清理,架构
+- 2026-03-16 16:00 | 创建hot-memory技能,实现热记忆模式 | 技能开发,架构
+- 2026-03-16 15:00 | 安装LanceDB-Pro,配置BAAI/bge-large-zh-v1.5嵌入模型 | 配置,向量数据库
+
+### 2026-03-15
+
+- 2026-03-15 14:00 | 测试qmd-wrapper.sh脚本,验证强制CPU后端 | 测试,脚本
+- 2026-03-15 10:00 | 飞书渠道状态检查 | 配置检查
+
+### 2026-03-14
+
+- 2026-03-14 11:00 | 安装Tavily Search技能,配置API Key | 技能安装,搜索
+- 2026-03-14 10:00 | 创建AI早报定时任务,确定三分类格式 | 定时任务,自动化
+
---
-*文件大小: ~0.6KB | 限制: 4KB*
-*维护脚本: `hot-memory/scripts/daily_maintenance.py`*
+## 📚 学习事件
+
+> 记录从陷阱和教训中学习的经验。
+> 所有学习记录永久保留,可使用 memory-md-archive 技能归档瘦身。
+
+- 2026-03-17 13:11 | 学习Shell特殊字符转义问题 | Shell,转义,特殊字符
+
+---
+
+*文件大小: ~1.5KB | 事件数: 14*
+*维护脚本: `memory-md-hot/scripts/daily_maintenance.py`*
+*归档提示: 文件较大时请使用 memory-md-archive 技能归档*
diff --git a/workspace/skills/memory-md-hot/scripts/daily_maintenance.py b/workspace/skills/memory-md-hot/scripts/daily_maintenance.py
index 310d2ef..673258a 100755
--- a/workspace/skills/memory-md-hot/scripts/daily_maintenance.py
+++ b/workspace/skills/memory-md-hot/scripts/daily_maintenance.py
@@ -124,6 +124,7 @@
def update_memory_file(new_daily_events=None, important_event=None):
"""
更新 memory.md 文件
+ 【限制:只修改"重要事件"和"最近7天事件流水"区块,其他内容保持不变】
Args:
new_daily_events: 新的每日事件列表 [(date, time, summary, keywords), ...]
@@ -172,7 +173,7 @@
result['added_important'] = True
result['messages'].append(f"重要事件已记录: {summary}")
- # 重新构建文件内容
+ # 重新构建文件内容 - 只修改指定区块,保留其他内容
today = datetime.now().strftime('%Y-%m-%d')
# 按日期分组日常事件
@@ -185,7 +186,7 @@
daily_by_date[date_str] = []
daily_by_date[date_str].append(line)
- # 构建日常事件区块
+ # 构建日常事件区块内容
daily_sections = []
for date_str in sorted(daily_by_date.keys(), reverse=True):
daily_sections.append(f"\n### {date_str}\n")
@@ -193,43 +194,34 @@
daily_content = ''.join(daily_sections) if daily_sections else f"\n### {today}\n\n- {today} --:-- | 暂无记录 | --\n"
- # 构建重要事件区块
+ # 构建重要事件区块内容
important_content = '\n'.join(new_important) if new_important else "<!-- 重要事件在此添加 -->"
# 计算统计
total_events = len(all_daily) + len(new_important)
result['total_events'] = total_events
- # 组装最终内容
- current_size = get_file_size()
- result['current_size_kb'] = round(current_size / 1024, 2)
+ # 【关键】使用正则替换只修改指定区块,保留其他所有内容
+ new_content = content
- new_content = f"""# MEMORY.md - 热记忆 / 活跃记忆
-
-> 本文件记录近期发生的重要事情,详细信息可通过记忆检索获取。
-
----
-
-## 🔔 重要事件
-
-> 记录具有全局长期性影响的重要决策和事件。
-> 添加重要事件时会告知用户。
-
-{important_content}
-
----
-
-## 📅 事件流水
-
-> 按天分组,每天主要事情的概要。
-> 所有记录永久保留,可使用 memory-md-archive 技能归档瘦身。
-{daily_content}
----
-
-*文件大小: ~{result['current_size_kb']:.1f}KB | 事件数: {total_events}*
-*维护脚本: `memory-md-hot/scripts/daily_maintenance.py`*
-*归档提示: 文件较大时请使用 memory-md-archive 技能归档*
-"""
+ # 替换重要事件区块(## 🔔 重要事件 和 ## 📅 事件流水 之间)
+ important_pattern = r'(## 🔔 重要事件\n\n> 记录具有全局长期性影响的重要决策和事件。\n> 添加重要事件时会告知用户。\n\n)(.*?)(\n---\n\n## 📅 事件流水)'
+ important_replacement = r'\1' + important_content + r'\3'
+ new_content = re.sub(important_pattern, important_replacement, new_content, flags=re.DOTALL)
+
+ # 替换事件流水区块(## 📅 事件流水 和下一个 ## 或文件末尾之间)
+ # 找到事件流水区块的结束位置(下一个 ## 标题或文件末尾的 ---)
+ daily_pattern = r'(## 📅 最近7天事件流水\n\n> 按天分组,每天主要事情的概要。\n> 自动维护,8天前的记录会被移除。)(.*?)(\n---\n\n## 📚 学习事件|\n---\n\n\*文件大小:)'
+
+ # 检查是否有学习事件区块
+ if '## 📚 学习事件' in new_content:
+ daily_replacement = r'\1' + daily_content + r'\3'
+ new_content = re.sub(daily_pattern, daily_replacement, new_content, flags=re.DOTALL)
+ else:
+ # 没有学习事件区块,替换到文件末尾
+ daily_pattern_simple = r'(## 📅 最近7天事件流水\n\n> 按天分组,每天主要事情的概要。\n> 自动维护,8天前的记录会被移除。)(.*?)(\n---\n\n\*文件大小:)'
+ daily_replacement = r'\1' + daily_content + r'\3'
+ new_content = re.sub(daily_pattern_simple, daily_replacement, new_content, flags=re.DOTALL)
# 写入文件
write_memory_file(new_content)
diff --git a/workspace/skills/memory-md-learning/scripts/learning.py b/workspace/skills/memory-md-learning/scripts/learning.py
index bdeaab9..c0de94c 100755
--- a/workspace/skills/memory-md-learning/scripts/learning.py
+++ b/workspace/skills/memory-md-learning/scripts/learning.py
@@ -2,6 +2,7 @@
"""
memory-md-learning 学习记录脚本
记录陷阱、教训和解决方案到长期记忆和 MEMORY.md
+【限制:只修改"学习事件"区块,其他内容保持不变】
"""
import os
@@ -47,10 +48,10 @@
stripped = line.strip()
# 检测学习事件区块
- if '学习事件' in stripped and stripped.startswith('#'):
+ if '## 📚 学习事件' in stripped:
in_learning = True
continue
- elif stripped.startswith('#') and in_learning:
+ elif stripped.startswith('#') and in_learning and '学习事件' not in stripped:
in_learning = False
# 收集学习事件
@@ -119,6 +120,7 @@
def update_memory_md_learning(summary, keywords):
"""
更新 MEMORY.md 的学习事件区块
+ 【限制:只修改"学习事件"区块,其他内容保持不变】
"""
content = read_memory_file()
if not content:
@@ -162,48 +164,58 @@
if any(new_event.strip() in existing.strip() for existing in existing_events):
return {'added': False, 'message': '学习事件已存在'}
+ # 【关键】使用正则替换只修改学习事件区块,保留其他所有内容
# 找到学习事件区块并插入新事件
- lines = content.split('\n')
- new_lines = []
- in_learning = False
- learning_inserted = False
+ all_events = existing_events + [new_event]
+ events_content = '\n'.join(all_events)
- for i, line in enumerate(lines):
- stripped = line.strip()
+ # 替换学习事件区块内容(保留区块标题和说明)
+ learning_pattern = r'(## 📚 学习事件\n\n> 记录从陷阱和教训中学习的经验。\n> 所有学习记录永久保留,可使用 memory-md-archive 技能归档瘦身。\n\n)(.*?)(\n---\n\n\*文件大小:)'
+ learning_replacement = r'\1' + events_content + r'\3'
+ new_content = re.sub(learning_pattern, learning_replacement, content, flags=re.DOTALL)
+
+ # 如果正则没有匹配到(格式可能不同),使用原来的方法
+ if new_content == content:
+ lines = content.split('\n')
+ new_lines = []
+ in_learning = False
+ learning_inserted = False
- # 检测学习事件区块开始
- if '## 📚 学习事件' in stripped:
- in_learning = True
- new_lines.append(line)
- continue
-
- # 检测学习事件区块结束(遇到下一个标题或文件末尾信息)
- if in_learning and stripped.startswith('#') and '学习事件' not in stripped:
- if not learning_inserted:
- new_lines.append(new_event)
- learning_inserted = True
- in_learning = False
- new_lines.append(line)
- continue
-
- # 在学习事件区块内,跳过空行后插入新事件
- if in_learning and not learning_inserted:
- if stripped == '' and i > 0 and '记录从陷阱' not in lines[i-1] and '所有学习记录' not in lines[i-1]:
- new_lines.append(new_event)
- new_lines.append('')
- learning_inserted = True
+ for i, line in enumerate(lines):
+ stripped = line.strip()
+
+ # 检测学习事件区块开始
+ if '## 📚 学习事件' in stripped:
+ in_learning = True
+ new_lines.append(line)
continue
+
+ # 检测学习事件区块结束(遇到下一个标题或文件末尾信息)
+ if in_learning and stripped.startswith('#') and '学习事件' not in stripped:
+ if not learning_inserted:
+ new_lines.append(new_event)
+ learning_inserted = True
+ in_learning = False
+ new_lines.append(line)
+ continue
+
+ # 在学习事件区块内,跳过空行后插入新事件
+ if in_learning and not learning_inserted:
+ if stripped == '' and i > 0 and '记录从陷阱' not in lines[i-1] and '所有学习记录' not in lines[i-1]:
+ new_lines.append(new_event)
+ new_lines.append('')
+ learning_inserted = True
+ continue
+
+ new_lines.append(line)
- new_lines.append(line)
-
- # 如果在文件末尾,确保插入了事件
- if in_learning and not learning_inserted:
- new_lines.append(new_event)
+ # 如果在文件末尾,确保插入了事件
+ if in_learning and not learning_inserted:
+ new_lines.append(new_event)
+
+ new_content = '\n'.join(new_lines)
# 更新文件大小信息
- new_content = '\n'.join(new_lines)
-
- # 更新文件大小统计
write_memory_file(new_content)
new_size = get_file_size()
size_kb = round(new_size / 1024, 2)
@@ -273,6 +285,13 @@
---
+## 📚 学习事件
+
+> 记录从陷阱和教训中学习的经验。
+> 所有学习记录永久保留,可使用 memory-md-archive 技能归档瘦身。
+
+---
+
*文件大小: ~0.5KB | 事件数: 0*
*维护脚本: `memory-md-hot/scripts/daily_maintenance.py`*
*归档提示: 文件较大时请使用 memory-md-archive 技能归档*
--
Gitblit v1.9.1