| name | reddit-snipe |
| description | Search Reddit (target subs + cross-Reddit search) for recent high-engagement threads about coding agents / Claude Code / AI dev tools, draft peer-builder English reply comments as the pikiclaw builder, push results to Feishu doc + bot. English-first. Does NOT auto-post to Reddit. |
| user-invocable | true |
| allowed-tools | Bash, Read, Write, Edit, Grep, Glob, Agent, WebFetch, mcp__pikiclaw-browser__browser_navigate, mcp__pikiclaw-browser__browser_take_screenshot, mcp__pikiclaw-browser__browser_snapshot, mcp__pikiclaw-browser__browser_press_key, mcp__pikiclaw-browser__browser_click, mcp__pikiclaw-browser__browser_evaluate, mcp__pikiclaw-browser__browser_type, mcp__pikiclaw-browser__browser_run_code, mcp__pikiclaw-browser__browser_wait_for, mcp__pikiclaw-browser__browser_tabs |
| argument-hint | [keyword] | [r/subreddit] | blank for full sweep |
Reddit-snipe: Reddit 热帖截流(英文为主)
在 Reddit 同领域社区/搜索结果中找到讨论 Claude Code / coding agent / AI dev tool 的高互动帖子,
始终以 pikiclaw builder 身份生成英文回复草稿,推送到飞书供人工审核。绝不自动发评论。
身份原则:从第一条评论开始就明确"I'm building pikiclaw"。不做匿名 karma-farming,
不在 OP 面前伪装成普通用户。Reddit 反自我营销文化是对推销话术的反感,不是对坦诚的 builder
的反感 — peer-builder 语气 + 真实回应 OP 痛点,本身就是被欢迎的。
战略前提(区别于 Twitter snipe)
Twitter 是 feed 截流场,Reddit 是社区贡献场。两套打法完全不同:
| 维度 | Twitter snipe | Reddit-snipe |
|---|
| 发现方式 | 关键词搜热帖 | 关键词搜 + 目标 sub 白名单巡逻 |
| 反营销文化 | 弱 | 强(针对推销话术,不针对坦诚 builder) |
| 时效性 | 强(24h 内最佳) | 弱(推特是 feed 流,新就有效;Reddit 是线程社区,旧热帖讨论持续,evergreen 价值更高) |
| 时间窗口 | 24h | 默认 14d(两周内),评论数 ≥ 5 的热帖优先;24h+ 新帖也保留 |
| 身份 | 跟随账号 persona | 始终是 pikiclaw builder,开门见山 |
| 回复语气 | 一句差异化 + 链接 | peer-builder:"I'm building X — saw your thread about Y" |
| 语言 | 跟原帖 | 默认英文(账号定位英文用户群体) |
| 是否带链接 | 总是 | 默认带(npx + GitHub);少数明确禁外链的 sub 改为只口头提 |
| 内容长度 | ≤3 句 | 2-4 句,必须先回应 OP 的具体问题 |
| 风险 | 封号 | 评论被 mod / automod 删(应对:选 sub + 不重复话术) |
当前 Reddit 账号现状(每次运行前检查)
- 用户名:
u/Appropriate-Seat-534(Reddit 自动生成,throwaway 模式 — 不利于信任)
- Display name:
owaowo 👾
- About:
AI generalist shipping across big & small orgs 🎮 Coding (Trae @ ByteDance) · Search (Reddo founder) · E-com (Dewu) · Health (Theta) Currently building pikiclaw 🦞 — open agent orchestrator
- Social:Twitter @sthnavy / GitHub
- 已加入 sub:仅
r/singapore
评论形态由 sub 规则决定,不由 karma 决定:
- 默认形态:完整 builder 评论,含
npx pikiclaw@latest + GitHub 链接
- 个别 sub 规则明确禁外链 / 禁 self-promo 链接 → 同一份草稿去掉链接行(口头提 pikiclaw 名字即可)
- 极严 sub(见
target_subreddits.md 标 skip 的)→ 本次直接跳过该 sub,不评论
karma 高低不改变身份。Reddit 的反感是针对推销话术,不是针对坦诚的 builder — 只要是真实回应
OP 痛点 + 不堆功能 + 不贬低同行,第一条评论就可以是 builder 身份。
工作流
Step 0: 读取已处理记录
读取 .pikiclaw/skills/reddit-snipe/sniped_threads.txt。每行格式:
<thread_url> | <ISO timestamp> | <link|no-link|skipped>
后续用 thread URL 去重。link / no-link 仅记录该次草稿形态,便于回看 sub 规则学习。
Step 2: 决定本轮检索来源
用户传入参数时:
r/<subname> → 只巡逻这一个 sub 的 hot + new 前两页
- 其他字符串 → 作为 Reddit 全站搜索关键词
- 空 → 走默认 sweep(下面)
默认 sweep(无参数时)的两条平行通道:
A. 目标 sub 巡逻(高信号低噪声)
从 target_subreddits.md 读取白名单,对每个 sub 同时抓三个视图:
/hot/ — 当下热门
/new/ — 最新(捕获 < 24h 的新生帖)
/top/?t=week 或 /top/?t=month — 关键,evergreen 高热度帖在这里
B. 跨 sub 关键词搜索(覆盖白名单之外的讨论)
对每个关键词访问两个 sort 维度(短时效新 + 长时效热):
https://www.reddit.com/search/?q={url-encoded-keyword}&type=link&sort=new&t=week
https://www.reddit.com/search/?q={url-encoded-keyword}&type=link&sort=top&t=month
不要再用 t=day 单一窗口 — Reddit 不是 feed 平台,老帖不会"过时",只会沉到底但仍能被搜到。
关键词池(English-first):
claude code alternative
claude code mobile
claude code dashboard
claude code telegram
remote claude code
self host claude code
codex cli alternative
gemini cli alternative
open source coding agent
multi agent coding
ai coding agent orchestrator
claude code on phone
coding agent wrapper
关键词不应固定记忆某个产品名,应捕获场景。某个关键词没结果就跳过,不要硬钻。
Step 3: 抽取页面数据
对每个抓取页面(sub 列表页 / 搜索结果页):
- 等待页面加载(确认
shreddit-post 出现)。
- 读取
.pikiclaw/skills/reddit-snipe/scripts/extract_reddit_threads.js 内容。
- 通过
browser_evaluate 注入执行,得到 JSON 字符串。
- 解析为 thread 数组。
每条 thread 至少有:subreddit, author, title, body_preview, url, score, comments, age_hours, post_type, external_url, has_product_signal, lang.
Step 4: 筛选候选
必须满足(hard filter):
- 不在
sniped_threads.txt
age_hours <= 336(14 天上限;Reddit 线程长尾,evergreen 讨论价值高于 timeliness)
- 英文为主(
lang === 'en',非英文跳过)
- 非自己(author 不是
u/Appropriate-Seat-534)
- thread 还活着:未 locked / archived(Reddit 6 个月自动 archive 后无法评论)
- 与 pikiclaw 功能交集:coding agent / Claude Code / Codex / Gemini CLI / agent dashboard / IM 接入 / 多会话管理 / 远程控制 / mobile / 插件 / skill / MCP
热度门槛(任一满足即可):
- 新帖(age < 24h):
comments >= 3 或 score >= 5(早进有先发优势)
- 中等期(1d ≤ age < 7d):
comments >= 10 或 score >= 20(已经积累一些讨论)
- 旧帖(7d ≤ age < 14d):
comments >= 30 或 score >= 100(必须是社区里有持续 visibility 的高热度帖)
优先级(高 → 低):
- OP 在求解一个具体痛点,且这个痛点 pikiclaw 能直接回应(最高价值 — 真正的 peer-help。时效不重要:旧帖只要还在被人搜到 / mod 推荐,价值不减)
- 高热度 evergreen 讨论帖(数百评论的工具比较 / 经验分享)— 即使旧也持续被人 Google 索引到
- OP 在 launch 自家工具,且功能交集大(可以礼貌地切入差异化)
- OP 在讨论/比较 Claude Code / Codex / Gemini 等工具(pikiclaw 作为另一种选择补充)
- 泛 AI dev tool 讨论(低优先级,曝光为主)
Reddit ≠ Twitter:时效性不是核心信号,讨论质量 + 持续 visibility 才是。一条 7 天前 500 评论的"哪个 coding agent 最好"帖,价值远高于一条 1 小时前 0 评论的新帖。
排除:
- 纯 meme / 抱怨 / 政治
- 已被 mod 锁定 / 已删除
- 在
target_subreddits.md 中标 skip 的 sub(mod 极严,任何第三方工具评论都会删 — 不浪费 ammo)
- author karma 极低 / 账号一周内注册的(容易是 spam,回复 ROI 低)
选 Top 3-5 条候选。
Step 5: 生成回复草稿(始终 builder 身份)
默认模板(带 npx + 链接):
I'm building pikiclaw — an open, layered agent orchestrator (Claude Code / Codex / Gemini CLI in one dashboard, IM bridge optional).
{一句直接回应 OP 的具体问题/痛点 — 必须 ground 在原帖具体文字上,不能泛泛}
{可选:一句 file/function 级证据,证明非营销吹水,例如 "the multi-session switching lives in agent/stream.ts"}
`npx pikiclaw@latest` · https://github.com/xiaotonng/pikiclaw
Happy to dig in if any of that lines up with what you're after.
no-link 变体(仅当 sub 在 target_subreddits.md 标 link: no 时使用,去掉命令 + 链接行):
I'm building pikiclaw — an open agent orchestrator that runs Claude Code / Codex / Gemini CLI in one dashboard, with optional IM bridges.
{一句直接回应 OP 的具体问题/痛点}
{可选:一句 file/function 级证据}
Curious if it lines up with what you're after — happy to share more if useful.
通用规则
- 永远英文(除非 OP 显式用其他语言且 sub 是该语言社区)
- peer-builder 语气:
I'm building 而非 Check out;Curious if 而非 You should try
- 不贬低任何竞品:Claude Code / Cursor / Codex / Aider / 等都是同行;pikiclaw 是补充不是替代
- 不堆功能:每条评论最多提 2 个差异点,必须和 OP 痛点对得上
- 不复制粘贴:每条草稿独立 draft,不能是同一段模板换个开头
- 每条草稿尾部加一行 meta:
<!-- 适用 sub: r/X · OP 痛点: ... · 差异点: ... -->(飞书报告里展示,发评论前删掉)
差异化切入角度(按 pikiclaw 实际优势排序,挑与 OP 最相关的一个)
重要:参考 memory 中"don't fabricate differentiation"反馈 — 只用 UX/execution 上真实成立的差异点,show-don't-tell。
- 对方在管单 agent / 单会话 → "Dashboard runs multiple Claude/Codex/Gemini sessions side-by-side, switch via tabs"
- 对方体验粗糙 / 配置复杂 → "Single
npx start, no config files, dashboard auto-opens"
- 对方生态封闭 → "Open skill/MCP plugin model — drop in community skills, they work in every session"
- 对方闭源 SaaS → "Fully OSS, runs entirely local, your conversations and code never leave the machine"
- 对方 CLI-only → "Web dashboard for full session control in the browser"
- 对方只能桌前用 → "Optional IM bridge (Telegram / Feishu / WeChat) lets you take over the same session from your phone"
- 对方单平台 → "macOS desktop automation + Playwright browser control built in"
Step 6: 生成报告 Markdown
写入 /tmp/reddit_snipe_report.md:
# Reddit-snipe 候选 — {YYYY-MM-DD}
**扫描范围**: {sub 列表 / 关键词 / 单独参数}
**候选数**: {n}
**当前 karma**: {n}(仅作运营参考,不影响身份)
---
## 候选 1: {title 前 60 字}
- **Sub**: r/{sub}
- **作者**: u/{author}
- **链接**: {url}
- **数据**: {score} ↑ / {comments} 💬 / 发布 {age_hours}h 前
- **OP 痛点 / 主题**: {一句话总结 OP 在求什么 / 推什么}
- **与 pikiclaw 交集**: {功能重叠点}
- **差异切入**: {选了哪个差异点,为什么}
- **草稿形态**: {link | no-link}(按 sub 规则)
### 推荐评论
> {draft}
---
## 候选 2: ...
...
---
## 操作指南
1. 优先回复候选 1(信号最强),依次往下
2. 发评论前手动 review:
- 是否真的回应了 OP 的具体问题?(如果只是泛泛"我也做了一个 X"则不发)
- sub 规则是否允许这类评论?(不确定就只点 upvote 不发)
3. 发完后将 thread URL 追加到 `.pikiclaw/skills/reddit-snipe/sniped_threads.txt`:
`<url> | <ISO timestamp> | <link|no-link|skipped>`
4. 隔天回访候选,看回复是否被 mod 删 / 被 OP 回应
Step 7: 推送到飞书
cd /Users/admin/Desktop/project/pikiclaw && \
python3 .pikiclaw/skills/snipe/scripts/push_feishu.py \
--report-file /tmp/reddit_snipe_report.md \
--title "🦞 Reddit Snipe 候选"
输出含义同 snipe skill(OK: / PARTIAL: / ERROR:)。ERROR 时把报告内容直接贴在对话里作为兜底。
Step 8: 更新去重记录
将本轮所有候选 thread URL 追加到 .pikiclaw/skills/reddit-snipe/sniped_threads.txt,
格式 <url> | <ISO timestamp> | <link|no-link|skipped>。即使最终没发评论也记录 —
避免下次重新评估同一帖;skipped 用于"评估过但 sub 规则不允许"的情况。
反模式(必须拒绝)
- ❌ 不读 OP 帖就堆 pikiclaw 功能介绍
- ❌ "Hey, you should check out pikiclaw" / "Try pikiclaw, it's better" 这类推销语
- ❌ 一帖回复多条评论(mod 直接 ban)
- ❌ 贬低任何竞品(Claude Code / Cursor / Aider / Cline 等都是同行)
- ❌ 在
target_subreddits.md 标 skip 的 sub 留评论 — 浪费 ammo,账号易被标记
- ❌ 用中文回复英文帖(账号定位是英文用户群体)
- ❌ 在 launch 帖下直接对比"pikiclaw 比你这个好" — 永远是补充不是替代
- ❌ 把"虚构的差异点"包装成卖点(参考 memory:don't fabricate differentiation)
- ❌ 隐藏 builder 身份装普通用户(karma-farming 模式被 mod 识破后信任清零)
边界与安全
- 绝不自动发评论 — push_feishu.py 是输出层,发评论永远人工
- 每天最多 3 条评论 — 防 mod / automod 风控
- 同一 sub 24h 内最多 1 条评论 — 防 sub-level 限频
- 飞书凭证沿用项目根
.env(FEISHU_APP_ID / FEISHU_APP_SECRET / FEISHU_CHAT_ID)
浏览器发评论的操作要点(实跑踩坑后总结)
如果走浏览器自动化(而非 Reddit API)发评论或编辑评论,注意以下技术细节:
- Reddit 评论框是 Lexical editor,普通
execCommand('insertText') 无效,必须用合成 ClipboardEvent('paste') 配合 DataTransfer.setData('text/plain', ...) 触发 Lexical 的 paste handler。
- paste 后立即回读
innerText 会拿到旧状态(DOM 还没 reconcile),用 len === 0 来判定失败是错的 — 等 ≥500ms 再读,或干脆只看截图。这次踩了这个坑,导致第二次重复粘贴,评论变成两份内容拼一起。
- Lexical 的 paste 不会替换当前 selection,会 append。如果是 "edit comment" 流程要替换全部内容,先
keyboard.press('ControlOrMeta+a') + keyboard.press('Delete') 清空编辑器,再 paste。
- collapsed composer:有些线程评论框初始是
<faceplate-textarea-input size="collapsed"> 状态,必须先点一次才会展开成带 contenteditable 的完整 composer。展开后再 paste。
- overflow menu 在 shadow DOM 内:编辑/删除评论的 "..." 按钮在
<shreddit-overflow-menu> 的 shadowRoot 里,要 comment.querySelector('shreddit-overflow-menu').shadowRoot.querySelector('button[aria-label="Open user actions"]')。
- 发送前再读一遍内容:clicking Comment 前必须再
evaluate 读 ed.innerText.length 验证 ≈ 期望草稿长度(容差 ±5%)。如果长度异常(0 或 2x),不要 click submit,回报失败让人工介入。
- 发送后用 thread DOM 验证:截图 +
document.querySelectorAll('shreddit-comment') 数我们的评论数和关键词出现次数(关键短语应只出现 1 次)。这是最后一道防线。
相关资源
- 目标 sub 白名单 + 每 sub 的 mod 严格度:
.pikiclaw/skills/reddit-snipe/target_subreddits.md
- DOM 抽取脚本:
.pikiclaw/skills/reddit-snipe/scripts/extract_reddit_threads.js
- 已处理记录:
.pikiclaw/skills/reddit-snipe/sniped_threads.txt
- 飞书推送(共用 snipe):
.pikiclaw/skills/snipe/scripts/push_feishu.py --title "🦞 Reddit Snipe 候选"