Manage and retrieve long-term memories with LanceDB using semantic vector search, category filtering, and detailed metadata storage.
数据来源:ClawHub。 在 ClawSkills 查看
选择你使用的 Agent
方法一:命令行安装(推荐)
推荐(无需提前安装 clawhub)
npx clawhub@latest --dir ~/.claude/skills install lancedb-memory或使用 clawhub CLI(需提前安装)
clawhub --dir ~/.claude/skills install lancedb-memory⚠️ 需要 Node.js 18+,没有 Node?请使用下方方法二直接下载 ZIP。 安装 Node.js →
方法二:手动下载安装(无需 Node)
下载 ZIP,解压后将文件夹放到以下路径,重启 Agent 即可:
安装路径
~/.claude/skills/lancedb-memory/💡解压后将文件夹放到上方路径,重启 Agent 即可生效
""" LanceDB integration for long-term memory management. Provides vector search and semantic memory capabilities. """
import os import json import lancedb from datetime import datetime from typing import List, Dict, Any, Optional from pathlib import Path
class LanceMemoryDB: """LanceDB wrapper for long-term memory storage and retrieval."""
def __init__(self, db_path: str = "/Users/prerak/clawd/memory/lancedb"): self.db_path = Path(db_path) self.db_path.mkdir(parents=True, exist_ok=True) self.db = lancedb.connect(self.db_path)
# Ensure memory table exists if "memory" not in self.db.table_names(): self._create_memory_table()
def _create_memory_table(self): """Create the memory table with appropriate schema.""" schema = [ {"name": "id", "type": "int", "nullable": False}, {"name": "timestamp", "type": "timestamp", "nullable": False}, {"name": "content", "type": "str", "nullable": False}, {"name": "category", "type": "str", "nullable": True}, {"name": "tags", "type": "str[]", "nullable": True}, {"name": "importance", "type": "int", "nullable": True}, {"name": "metadata", "type": "json", "nullable": True}, ]
self.db.create_table("memory", schema=schema)
def add_memory(self, content: str, category: str = "general", tags: List[str] = None, importance: int = 5, metadata: Dict[str, Any] = None) -> int: """Add a new memory entry.""" table = self.db.open_table("memory")
# Get next ID max_id = table.to_pandas()["id"].max() if len(table) > 0 else 0 new_id = max_id + 1
# Insert new memory memory_data = { "id": new_id, "timestamp": datetime.now(), "content": content, "category": category, "tags": tags or [], "importance": importance, "metadata": metadata or {} }
table.add([memory_data]) return new_id
def search_memories(self, query: str, category: str = None, limit: int = 10) -> List[Dict]: """Search memories using vector similarity.""" table = self.db.open_table("memory")
# Build filter where_clause = [] if category: where_clause.append(f"category = '{category}'")
filter_expr = " AND ".join(where_clause) if where_clause else None
# Vector search results = table.vector_search(query).limit(limit).where(filter_expr).to_list()
return results
def get_memories_by_category(self, category: str, limit: int = 50) -> List[Dict]: """Get memories by category.""" table = self.db.open_table("memory") df = table.to_pandas() filtered = df[df["category"] == category].head(limit) return filtered.to_dict("records")
def get_memory_by_id(self, memory_id: int) -> Optional[Dict]: """Get a specific memory by ID.""" table = self.db.open_table("memory") df = table.to_pandas() result = df[df["id"] == memory_id] return result.to_dict("records")[0] if len(result) > 0 else None
def update_memory(self, memory_id: int, **kwargs) -> bool: """Update a memory entry.""" table = self.db.open_table("memory")
valid_fields = ["content", "category", "tags", "importance", "metadata"] updates = {k: v for k, v in kwargs.items() if k in valid_fields}
if not updates: return False
# Convert to proper types for LanceDB if "tags" in updates and isinstance(updates["tags"], list): updates["tags"] = str(updates["tags"]).replace("'", '"')
table.update(updates, where=f"id = {memory_id}") return True
def delete_memory(self, memory_id: int) -> bool: """Delete a memory entry.""" table = self.db.open_table("memory") current_count = len(table) table.delete(f"id = {memory_id}") return len(table) < current_count
def get_all_categories(self) -> List[str]: """Get all unique categories.""" table = self.db.open_table("memory") df = table.to_pandas() return df["category"].dropna().unique().tolist()
def get_memory_stats(self) -> Dict[str, Any]: """Get statistics about memory storage.""" table = self.db.open_table("memory") df = table.to_pandas()
return { "total_memories": len(df), "categories": len(self.get_all_categories()), "by_category": df["category"].value_counts().to_dict(), "date_range": { "earliest": df["timestamp"].min().isoformat() if len(df) > 0 else None, "latest": df["timestamp"].max().isoformat() if len(df) > 0 else None } }
lancedb_memory = LanceMemoryDB()
def add_memory(content: str, category: str = "general", tags: List[str] = None, importance: int = 5, metadata: Dict[str, Any] = None) -> int: """Add a memory to the LanceDB store.""" return lancedb_memory.add_memory(content, category, tags, importance, metadata)
def search_memories(query: str, category: str = None, limit: int = 10) -> List[Dict]: """Search memories using semantic similarity.""" return lancedb_memory.search_memories(query, category, limit)
def get_memories_by_category(category: str, limit: int = 50) -> List[Dict]: """Get memories by category.""" return lancedb_memory.get_memories_by_category(category, limit)
def get_memory_stats() -> Dict[str, Any]: """Get memory storage statistics.""" return lancedb_memory.get_memory_stats()
if __name__ == "__main__": # Test the database print("Testing LanceDB memory integration...")
# Add a test memory test_id = add_memory( content="This is a test memory for LanceDB integration", category="test", tags=["lancedb", "integration", "test"], importance=8 ) print(f"Added memory with ID: {test_id}")
# Search for memories results = search_memories("test memory") print(f"Search results: {len(results)} memories found")
# Get stats stats = get_memory_stats() print(f"Memory stats: {stats}")
安装 Lancedb Memory 后,可以对 AI 说这些话来触发它
Help me get started with Lancedb Memory
Explains what Lancedb Memory does, walks through the setup, and runs a quick demo based on your current project
Use Lancedb Memory to manage and retrieve long-term memories with LanceDB using semantic ...
Invokes Lancedb Memory with the right parameters and returns the result directly in the conversation
What can I do with Lancedb Memory in my documents & notes workflow?
Lists the top use cases for Lancedb Memory, with example commands for each scenario
将技能文件夹放到 ~/.claude/skills/lancedb-memory/ 目录(个人级,所有项目可用),或 .claude/skills/lancedb-memory/(项目级)。重启 AI 客户端后,用 /lancedb-memory 主动调用,或让 AI 根据上下文自动发现并使用。
Lancedb Memory 支持 Claude、Cursor、OpenClaw,可与这些 AI 平台无缝集成,扩展其能力。
Lancedb Memory 可免费安装使用。请查阅仓库了解许可证信息。
Manage and retrieve long-term memories with LanceDB using semantic vector search, category filtering, and detailed metadata storage.
Lancedb Memory 属于「Documents & Notes」分类,该分类的技能帮助 AI 智能体在此领域执行专业任务。
Automate my documents & notes tasks using Lancedb Memory
Identifies repetitive steps in your workflow and sets up Lancedb Memory to handle them automatically