<a href="https://go.warp.dev/fabric" target="_blank">
<sup>特别鸣谢:</sup>
<img alt="Warp sponsorship" width="400" src="https://raw.githubusercontent.com/warpdotdev/brand-assets/refs/heads/main/Github/Sponsor/Warp-Github-LG-02.png">
<h>Warp,专为多 AI 智能体编程而生</b>
<sup>支持 macOS, Linux 和 Windows</sup>
</a>

fabricfabric 是一个使用 AI 来增强人类能力的开源框架。English · 中文

更新日志 • 什么是 Fabric 及其原因 • 哲学理念 • 安装指南 • 使用方法 • REST API • 示例 • 直接使用 Patterns • 自定义 Patterns • 辅助应用 • 元数据
自 2022 年底现代 AI 兴起以来,我们看到了海量的用于完成任务的 AI 应用。有成千上万的网站、聊天机器人、移动应用和其他接口可供使用。
这一切都非常令人兴奋且强大,但是_将这些功能整合到我们的生活中并不容易_。
Fabric 的诞生就是为了解决这个问题,通过创建和组织 AI 的基本单元——Prompt(提示词)本身!
Fabric 按照现实世界中的任务来组织 Prompt,允许人们在一个地方创建、收集和组织他们最重要的 AI 解决方案,以便在他们最喜欢的工具中使用。如果你喜欢命令行,你甚至可以直接把 Fabric 本身作为接口使用!
若想深入了解 Fabric 及其内部机制,请阅读 docs 文件夹 中的文档。这里还有一个极其有用且定期更新的 Fabric DeepWiki。
点击查看最近更新
亲爱的用户:
我们在 Fabric 做了很多激动人心的事情,我想在这里做一个简短的总结,让您感受一下我们的开发速度!
以下是我们添加的新功能和特性(最新在前):
azurecommon 包中。/swagger/index.html 添加了 Swagger/OpenAPI UI。openai-go/azure SDK。--transcribe-file、--transcribe-model 和 --split-media-file 标志。这些功能代表了我们致力于使 Fabric 成为最强大、最灵活的 AI 增强框架的承诺!
请注意,以下很多视频是在 Fabric 还是基于 Python 的时代录制的,所以请务必使用下方最新的安装指南。
fabricFabric 正在快速演进。
请查阅 CHANGELOG 了解所有最新变更。
我们在日常工作和生活中经常遇到的问题是难以自动化完成一件大而复杂的事情。
以"写一篇文章"为例。这很难做到,即使对 AI 而言也是如此。为什么呢?因为你要写什么?谁是你的受众?写作基调是怎样的?一旦写完,你打算把它放在哪里?你需要配合图片吗?
解决复杂系统的最佳方法是将它们分解成单一职责的组件(模块)。
这就引出了我们对 Prompt 的处理方法。我们不仅需要将问题分解为组件,我们还需要让这些组件具有独立存在的价值。并且我们需要为这些组件命名,这样我们就能快速找到它们。
在 Fabric 之前,你可能有很多 Prompt 散落在你的笔记、桌面文件中,或者只存在于你的脑海里。
[!NOTE] Fabric 的核心是一个包含独立、针对特定问题的 Markdown 格式 Prompt 库,我们称之为
Patterns(模式)。
除了这套精心构建的 Prompt 之外,Fabric 还提供了一套原生于 Go 语言(过去是 Python)的命令行工具。
Fabric 拥有适用于各种生活和工作场景的 Patterns,包括:
Unix/Linux/macOS:
curl -fsSL https://raw.githubusercontent.com/danielmiessler/fabric/main/scripts/installer/install.sh | bash
Windows PowerShell:
iwr -useb https://raw.githubusercontent.com/danielmiessler/fabric/main/scripts/installer/install.ps1 | iex
请参阅 scripts/installer/README.md 了解自定义安装选项和故障排除。
最新发布的二进制存档及其 SHA256 哈希值可在 https://github.com/danielmiessler/fabric/releases/latest 找到。
注意: 使用 Homebrew 或 Arch Linux 包管理器安装时,fabric 命令名称为 fabric-ai,请在 shell 配置文件中添加以下别名:
alias fabric='fabric-ai'
brew install fabric-ai
yay -S fabric-ai
使用 Microsoft 官方支持的 Winget 工具:
winget install danielmiessler.Fabric
scoop install fabric-ai
安装 Fabric 前,请先确保已安装 Go,然后运行:
go install github.com/danielmiessler/fabric/cmd/fabric@latest
使用预构建的 Docker 镜像运行 Fabric:
# 使用 Docker Hub 的最新镜像
docker run --rm -it kayvan/fabric:latest --version
# 使用 GHCR 的特定版本
docker run --rm -it ghcr.io/ksylvan/fabric:v1.4.305 --version
# 首次运行时进行配置
mkdir -p $HOME/.fabric-config
docker run --rm -it -v $HOME/.fabric-config:/home/appuser/.config/fabric kayvan/fabric:latest --setup
# 使用你的 patterns
docker run --rm -it -v $HOME/.fabric-config:/home/appuser/.config/fabric kayvan/fabric:latest -p summarize
# 运行 REST API 服务器
docker run --rm -it -p 8080:8080 -v $HOME/.fabric-config:/home/appuser/.config/fabric kayvan/fabric:latest --serve
镜像来源:
请参阅 scripts/docker/README.md 了解自定义镜像构建和高级配置。
在 Linux 上你可能需要在 ~/.bashrc,在 macOS 上需要在 ~/.zshrc 中设置环境变量,以便运行 fabric 命令。
Intel Mac 或 Linux:
# Golang 环境变量
export GOROOT=/usr/local/go
export GOPATH=$HOME/go
# 更新 PATH
export PATH=$GOPATH/bin:$GOROOT/bin:$HOME/.local/bin:$PATH
Apple Silicon Mac:
# Golang 环境变量
export GOROOT=$(brew --prefix go)/libexec
export GOPATH=$HOME/go
export PATH=$GOPATH/bin:$GOROOT/bin:$HOME/.local/bin:$PATH
Fabric 还支持通过环境变量配置语言和默认模型:
export FABRIC_LANG="zh"
export FABRIC_DEFAULT_MODEL="claude-sonnet-4-5-20251022"
fabric --setup
原生集成:
OpenAI 兼容供应商:
运行 fabric --setup 配置首选供应商,或使用 fabric --listvendors 查看所有可用供应商。
你可以使用环境变量为单个 pattern 配置特定模型,格式为 FABRIC_MODEL_PATTERN_NAME=vendor|model。可以在 shell 启动文件中维护这些按 pattern 的模型映射。
在 .zshrc 或 .bashrc 中添加以下内容,可以直接使用 pattern 名称作为命令(例如,用 summarize 代替 fabric --pattern summarize):
for pattern_file in $HOME/.config/fabric/patterns/*; do
pattern_name="$(basename "$pattern_file")"
alias_name="${FABRIC_ALIAS_PREFIX:-}${pattern_name}"
alias_command="alias $alias_name='fabric --pattern $pattern_name'"
eval "$alias_command"
done
yt() {
if [ "$#" -eq 0 ] || [ "$#" -gt 2 ]; then
echo "Usage: yt [-t | --timestamps] youtube-link"
return 1
fi
transcript_flag="--transcript"
if [ "$1" = "-t" ] || [ "$1" = "--timestamps" ]; then
transcript_flag="--transcript-with-timestamps"
shift
fi
local video_link="$1"
fabric -y "$video_link" $transcript_flag
}
如果你已安装旧版(Python 版),以下是迁移到 Go 版本的步骤:
# 卸载旧版 Fabric
pipx uninstall fabric
# 清理旧的 Fabric 别名(检查 .bashrc、.zshrc 等)
# 安装 Go 版本
go install github.com/danielmiessler/fabric/cmd/fabric@latest
# 运行新版配置
fabric --setup
然后按照上方说明设置环境变量。
得益于 Go 的特性,升级非常简单,只需运行安装时相同的命令即可获取最新版本:
go install github.com/danielmiessler/fabric/cmd/fabric@latest
Fabric 提供了 Zsh、Bash 和 Fish 的 shell 补全脚本,让 CLI 使用更加便捷。
快速安装(无需克隆仓库):
curl -fsSL https://raw.githubusercontent.com/danielmiessler/Fabric/refs/heads/main/completions/setup-completions.sh | sh
Zsh 补全:
mkdir -p ~/.zsh/completions
cp completions/_fabric ~/.zsh/completions/
echo 'fpath=(~/.zsh/completions $fpath)' >> ~/.zshrc
echo 'autoload -Uz compinit && compinit' >> ~/.zshrc
Bash 补全:
echo 'source /path/to/fabric/completions/fabric.bash' >> ~/.bashrc
Fish 补全:
mkdir -p ~/.config/fish/completions
cp completions/fabric.fish ~/.config/fish/completions/
配置完成后,运行以下命令查看帮助:
fabric -h
处理 YouTube 视频时,还可以使用以下视觉提取选项:
--visual:使用 OCR 和 FFmpeg 从视频中提取视觉信息--visual-sensitivity:设置 FFmpeg 场景检测的容差(0.0 - 1.0)--visual-fps:按固定每秒帧数提取画面,而不是使用场景检测将你复制的任何文本流式输入到 fabric 并选择你想应用的 Pattern:
pbpaste | fabric --pattern extract_wisdom
使用 --debug 标志控制运行时日志:
0:关闭(默认)1:基本调试信息2:详细调试3:追踪级别使用 --dry-run 预览将发送给 AI 模型的内容,而不实际发送请求:
echo "test input" | fabric --dry-run -p summarize
这对于调试 pattern、检查提示词构建以及在使用 API 配额之前验证输入格式非常有用。
Fabric 支持可在 pattern 中调用的扩展。请参阅 Extension Guide 获取完整文档。
重要提示: 扩展只能在 pattern 文件中使用,不能通过直接 stdin 使用。
Fabric 内置了 REST API 服务器,通过 HTTP 暴露所有核心功能。启动服务器:
fabric --serve
服务器提供以下端点:
有关完整的端点文档、身份验证设置和使用示例,请参阅 REST API 文档。
Fabric 可以通过暴露 Ollama 兼容的 API 端点,作为 Ollama 的直接替代品:
fabric --serve --serveOllama
这将启用以下 Ollama 兼容端点:
GET /api/tags — 将可用 pat$ claude mcp add Fabric \
-- python -m otcore.mcp_server <graph>