원클릭으로
从球探体育(titan007)抓取竞彩足球赛程数据。在用户说「抓取赛程」「获取今日比赛」「今天有什么比赛」或赛前分析流程启动时使用。
npx skills add https://github.com/philipbo/openclaw-pansuan --skill match-scraper이 명령을 Claude Code에 복사하여 붙여넣어 스킬을 설치하세요
从球探体育(titan007)抓取竞彩足球赛程数据。在用户说「抓取赛程」「获取今日比赛」「今天有什么比赛」或赛前分析流程启动时使用。
npx skills add https://github.com/philipbo/openclaw-pansuan --skill match-scraper이 명령을 Claude Code에 복사하여 붙여넣어 스킬을 설치하세요
每日定时检查(日历、待办、通知等),在用户说「今天有什么安排」或心跳/定时任务触发时使用。
从指定数据源抓取最新数据。在用户说「拉取数据」「同步一下」或流程需要最新数据时使用。
根据已有数据或上下文生成汇总报告。在用户说「生成报告」「总结一下」或流程需要输出报告时使用。
对初筛通过的比赛进行深度分析:数据抓取(分析页+赔率变化)→ 10 步分析(基本面→伤停→泊松→欧指→亚盘→大小球→合理性→关键点/疑点/矛盾→风险→综合评估+推荐)→ 写入记忆。**分析依据仅限公司数据**:胜平负非亚洲联赛威廉、365 必抓(欧洲两家交叉认证,德国为威廉+365+Interwetten 三家),亚洲联赛以澳彩+皇冠+365+易胜博+马会五家交叉认证;亚盘/大小球以澳彩、皇冠、365、易胜博四家(亚洲联赛加马会共五家)交叉认证。平博不参与分析依据,仅复盘时用于 CLV。自开盘不参与分析依据。在用户说「深度分析」「分析这场比赛」「详细看看」或赛前流程中初筛之后使用。
赛后复盘:获取比赛结果,对比推荐记录,计算命中率,分析失误原因,更新长期统计。在用户说「复盘」「昨天结果怎么样」「战绩」或每日09:30定时触发时使用。
汇总深度分析结果,逐场推送分析报告,最后发送汇总(含串关建议)。在用户说「给推荐」「今天买什么」「推荐」或赛前流程中深度分析之后使用。
| name | match-scraper |
| description | 从球探体育(titan007)抓取竞彩足球赛程数据。在用户说「抓取赛程」「获取今日比赛」「今天有什么比赛」或赛前分析流程启动时使用。 |
| metadata | {"openclaw":{"emoji":"📆"}} |
从 https://jc.titan007.com/index.aspx 抓取当日竞彩足球全量赛程数据。
agent-browser CLI 已安装且可用(通过 Shell 调用)如果是 Cron 定时触发(非用户手动询问),先检查当前时间是否在竞彩销售窗口内(时间边界以 AGENTS.md 六、可配置参数 为准:SCHEDULE_PUBLISH_TIME ~ SALES_CUTOFF_WEEKDAY / SALES_CUTOFF_WEEKEND):
如果当前时间不在销售窗口内 → 直接终止,不抓取数据,不执行后续流程。 向龙王发送一条简短通知:「当前不在竞彩销售时间内,跳过本次执行。」
用户手动询问(如"今天有什么比赛")不受此限制,任何时间都可以查询。
agent-browser open https://jc.titan007.com/index.aspx
agent-browser wait --load networkidle
如果超时,再等 5 秒后重试一次。
竞彩页面(jc.titan007.com)默认已显示全部赛事,无需点击「显示全部」。直接提取。
优先使用 eval 直接执行 JS 提取表格数据,重点提取比赛 ID:
⚠️ matchId 在 onclick 里,不在 href 里。页面的「析」链接格式为 <a href="javascript:" onclick="analysis(2958853);">析</a>,必须从 onclick 属性提取 matchId,而非 href。
⚠️ rowspan=2:每场比赛占两行 <tr>,matchId 所在的「数据」<td> 有 rowspan="2",仅挂在第一行。脚本只提取含 analysis() onclick 的行,自动跳过第二行,避免重复。
agent-browser eval '(() => {
const rows = document.querySelectorAll("#table_live tr[id]");
if (!rows.length) return [];
const results = [];
for (const tr of rows) {
const cells = Array.from(tr.cells).map(td => td.textContent.trim());
let matchId = null;
const analysisBtn = tr.querySelector("a[onclick*=\"analysis(\"]");
if (analysisBtn) {
const m = analysisBtn.getAttribute("onclick").match(/analysis\((\d+)\)/);
if (m) matchId = m[1];
}
if (!matchId) {
const barDiv = tr.querySelector("div[id^=\"bar_\"]");
if (barDiv) {
const m = barDiv.id.match(/bar_(\d+)/);
if (m) matchId = m[1];
}
}
if (matchId) {
results.push({ id: tr.id, matchId, cells });
}
}
return results;
})()'
提取逻辑(按优先级):
a[onclick*="analysis("],从 onclick="analysis(2958853)" 提取数字 → matchIddiv[id^="bar_"],从 id="bar_2958853" 提取数字 → matchId如果 eval 返回空数据或报错,退化到 snapshot 模式:
agent-browser snapshot
从 snapshot 文本中查找 analysis(数字) 模式提取比赛 ID,配合行文本解析队名和时间。
目的:只保留销售日期为今天的比赛,防止跨天比赛混入。
竞彩销售窗口规则:
过滤规则:
目的:把列表中的 HH:mm 转成正确的绝对时间 YYYY-MM-DD HH:mm,避免“凌晨场次被记到今天”的 BUG。
背景:竞彩销售日期窗口为 今天 11:00 ~ 明天 11:00。因此同一销售日(如“周二”)的比赛,可能出现在次日凌晨(00:00~10:59)。
规则(强制):
HH:mm 作为开球时刻:
HH:mm < 11:00 → 该场开球日期 = 销售日期 + 1 天(次日凌晨场)输出字段名统一:后续所有结构化输出中,将「时间」字段统一改为「开球」。
实现方式(在 eval 后添加过滤逻辑):
// 计算今天是星期几(1=周一,7=周日)
const weekdays = ["周日", "周一", "周二", "周三", "周四", "周五", "周六"];
const todayWeekday = weekdays[new Date().getDay()];
// 从 results 中提取竞彩编号(通常是第 1 列,格式 "周一 001" 或 "001")
const filteredResults = results.filter((r) => {
const numCell = r.cells[0] || ""; // 场号列,如 "周一 001"
// 检查编号是否包含今天的前缀
if (numCell.includes(todayWeekday)) return true;
// 如果没有前缀(仅数字),默认保留(可能是当天比赛)
if (/^\d+$/.test(numCell.trim())) return true;
return false;
});
备选方案(如果编号列无前缀):
过滤后处理:
先输出日期汇总头,再按编号升序逐场列出:
⚽ **{星期X} {YYYY-MM-DD}** 共{N}场比赛
| 编号 | 对阵 | 开球 | 联赛 |
| ------- | ------------------ | ---------------- | ------ |
| {编号} | [{主队} VS {客队}](https://zq.titan007.com/analysis/{matchId}cn.htm) | {开球 YYYY-MM-DD HH:MM} | {联赛} |
| ... | ... | ... | ... |
同时保存结构化数据供后续 skill 使用(每场一条):
- 编号: {竞彩编号}
比赛ID: {matchId}
联赛: {联赛名称}
联赛层级: {高/中/低/排除}
开球: {YYYY-MM-DD HH:mm}
状态: {未开场/进行中/已完场}
主队: {主队名}
比分: {比分或 - }
客队: {客队名}
分析页: https://zq.titan007.com/analysis/{matchId}cn.htm
联赛层级预分类规则(供 match-screening 阶段1 直接使用):
比赛 ID 是后续深度分析的关键,用于直接拼接分析页 URL,无需再从列表页点击跳转。
首次运行检查:写入前确认 memory/ 目录存在。如果不存在,先创建该目录。
将赛程摘要追加写入 memory/{今天日期}.md(不覆盖已有赛程 section,同一天可保留多段)。
Section 标题:使用 ## 赛程抓取({执行时间 HH:MM}),例如 ## 赛程抓取(11:10)、## 赛程抓取(14:25)。每次赛程同步在文件末尾追加上述 section。初筛、分析编号、编排流程以当日 memory 中最后一个以 ## 赛程抓取 开头的 section 作为当前赛程列表。
格式:
## 赛程抓取(11:10)
⚽ {星期X} {YYYY-MM-DD} 共{N}场比赛
抓取时间:{当前时间}
- 未开场:{N} 场
- 进行中:{N} 场
- 已完场:{N} 场
### 赛程列表
{按编号升序的赛程数据}
如果需要查看非当天的赛程(如龙王说「看看昨天的比赛」,或复盘需要查历史赛程):
## 推荐(内容为「今日无竞彩赛事,无推荐」,但必须包含 ### 精选场次/候补场次/串关组合/CLV 追踪数据 这些块,表可为空),确保 post-review 解析一致将完整的结构化赛程列表返回,供后续 match-screening 使用。