Polymarket Temperature Event Follower
Automated trader for Polymarket weather highest temperature markets. Scans global weather markets and executes buys during local morning window (9-10 AM) when YES price is favorable. Built for SkillPay billing integration with robust error handling and state persistence.
安装 / 下载方式
TotalClaw CLI推荐
totalclaw install clawskills:stefantaylor5~polymarket-temperature-event-followercURL直接下载,无需登录
curl -fsSL https://skills.taituai.com/api/skills/clawskills%3Astefantaylor5~polymarket-temperature-event-follower/file -o polymarket-temperature-event-follower.mdGit 仓库获取源码
git clone https://github.com/openclaw/skills/commit/48df7ea0c17fe027712bdc752851c2710d3dab07# SkillPay Weather Sniper / 天气狙击机器人 **Polymarket 天气事件市场自动化交易系统** --- ## 📋 目录 1. [项目概述](#1) 2. [快速开始(5分钟)](#2) 3. [准备工作](#3) 4. [API 密钥获取教程](#4) 5. [配置文件详解 (.env)](#5) 6. [代码参数详解](#6) 7. [启动指南](#7) 8. [安全建议](#8) 9. [故障排查](#9) 10. [FAQ 常见问题](#10) --- <a name="1"></a> ## 1. 项目概述 / Project Overview ### 1.1 这是什么?/ What is this? 这是一个自动化交易机器人,用于在 **Polymarket** 预测市场平台上交易**天气事件**合约。 **核心功能**: - ✅ 实时扫描全球 33 个城市的天气市场 - ✅ 在气温预测确定窗口期(10:00-14:00)自动买入"今日高温超过阈值"的合约 - ✅ 集成 SkillPay 按次计费(每笔成功下单扣 0.01 USDT) - ✅ 异常容错:网络重试、余额检查、滑点保护 - ✅ 完整日志和状态持久化 ### 1.2 适合谁用?/ Who is this for? - 对天气预测市场感兴趣的交易者 - 想要自动化策略的开发者 - 学习 Polymarket API 和预测市场的新手 ### 1.3 核心策略 / Core Strategy ``` 假设:每日最高温通常出现在下午14:00-15:00(气象学原理) 逻辑: 1. 上午10:00后,官方气温预报已发布,市场不确定性降低 2. 当 YES token 价格低于 0.35 时,认为市场低估了"高温"概率 3. 以固定金额(默认 $1.0)买入,等待气温确定后价格上涨 4. 可在价格上涨后卖出,或持有至结算(自动按 $1.0 或 $0.0 结算) ``` --- <a name="2"></a> ## 2. 快速开始(5分钟)/ Quick Start (5 min) ### 2.1 前置条件 / Prerequisites - ✅ Python 3.9+(推荐 3.10-3.12) - ✅ 已注册 [Polymarket](https://polymarket.com) 账户 - ✅ 懂基本命令行操作 ### 2.2 一键启动脚本 / One-Command Setup ```bash # 1. 克隆/进入项目目录(你已经在了) cd C:\Users\19154\Desktop\skill # 2. 安装依赖(全程约 2 分钟) pip install -r requirements.txt # 3. 复制环境变量模板 copy .env.example .env # 然后编辑 .env 文件,填入你的密钥(见第4节) # 4. 测试运行(模拟模式,不花钱) python sniper.py --dry-run --once # 5. 看到扫描输出后,说明安装成功! # 6. 真实交易(谨慎!) python sniper.py --live --once ``` --- <a name="3"></a> ## 3. 准备工作 / Preparation ### 3.1 环境检查 / Environment Check ```bash # 检查 Python 版本(需要 3.9+) python --version # 预期输出: Python 3.10.x 或 3.11.x 或 3.12.x # 检查 pip pip --version ``` ### 3.2 创建虚拟环境(可选但推荐)/ Virtual Environment ```bash # Windows python -m venv venv venv\Scripts\activate # macOS/Linux python3 -m venv venv source venv/bin/activate ``` ### 3.3 依赖列表 / Dependencies 创建 `requirements.txt` 文件(如果不存在): ``` python-dotenv>=1.0.0 requests>=2.31.0 aiohttp>=3.9.0 pytz>=2024.1 eth-account>=0.11.0 py-clob-client>=0.2.0 # Polymarket 官方客户端(实盘必需) ``` 安装: ```bash pip install -r requirements.txt ``` --- <a name="4"></a> ## 4. API 密钥获取教程 / API Key Tutorial ### 4.1 Polymarket 凭证 / Polymarket Credentials #### 步骤 1:导出钱包(EOA 和 Proxy) 1. 访问 [Polymarket Settings](https://polymarket.com/settings) 2. 将metamask钱包登录到polymarket主页 3. 你需要以下信息: | 字段 | 说明 | 从哪里获取 | |------|------|-----------| | `PRIVATE_KEY` | 你的 EOA 钱包私钥(**绝密!**) | MetaMask 导出私钥(注意:不是助记词) | | `PROXY_WALLET` | Polymarket 代理钱包地址 | Settings 页面显示的 "Wallet Address" | | `POLY_API_KEY` | L2 API Key | 待会儿运行命令获得 | | `POLY_API_SECRET` | L2 API Secret | 待会儿运行命令获得 | | `POLY_API_PASSPHRASE` | L2 密码 | 待会儿运行命令获得 | #### 步骤 2:生成私钥(MetaMask) 1. 打开 MetaMask 扩展 2. 选择账户 → 更多 → "Account details" 3. 点击 "Export Private Key" 4. 输入密码确认 5. 复制以 `0x` 开头的 64 位十六进制字符串 ⚠️ **安全警告**: - 私钥 = 完全控制权!任何人拿到私钥可以转移所有资产 - 不要将私钥上传到 GitHub、云盘 - 建议使用**单独钱包**专门用于交易,不要存放大额资金 #### 步骤 3:确定 `SIGNER_TYPE` - 如果 `PRIVATE_KEY` 属于普通 EOA 钱包→ `SIGNER_TYPE = "2"` - 如果使用 Gnosis Safe 多签 → `SIGNER_TYPE = "2"`(推荐) 大多数用户选择 `"1"`。 选择1的时候 可以不用运行命令获取L2凭证,直接用邮箱注册polymarket获得一个私钥钱包 去设置页面获取生成L2凭证并且导出私钥 然后复制代理钱包地址 Polymarket 官网看到的钱包地址(通常以 0x 开头),它持有你的 USDC.e 资金。 PRIVATE_KEY: 你的邮箱钱包私钥。你需要从官方导出页面获取。 --- #### 步骤 4:确定 `L2凭证` 在代码所在目录下运行 python sniper.py --live --once 命令行会返回3个凭证 依次填入.env文件中 ### 4.2 SkillPay **注意**: - 这是按次计费服务,每成功下单一次扣除 **0.01 USDT** - 如果余额不足,下单会失败(系统会提示充值链接) - 最低充值金额:**8 USDT**(相当于 800 次调用额度) --- ### 4.3 userId / 用户ID `SKILLPAY_USER_ID`:同PROXY_WALLET的值 <a name="5"></a> ## 5. 配置文件详解 / Configuration 所有配置通过**环境变量**(`.env` 文件)管理。 ### 5.1 创建 `.env` 文件 在项目根目录创建文件 `.env`,内容如下: ```ini # ============================================ # 必填:Polymarket 认证 # ============================================ PRIVATE_KEY=0xsk_your_private_key_here_64_hex_chars PROXY_WALLET=0x1234567890123456789012345678901234567890 POLY_API_KEY=pk_live_xxxxxxxxxxxxxxxxxxxx POLY_API_SECRET=sk_live_xxxxxxxxxxxxxxxxxxxx POLY_API_PASSPHRASE=your_passphrase_here SIGNER_TYPE=1 # 1=邮箱账户, 2=metamask注册的polymarket账户 # ============================================ # 交易参数(建议保持默认) # ============================================ TRADE_AMOUNT_USD=1.0 # 每笔下单金额(美元) MIN_ORDERBOOK_SIZE=1.0 # 最小订单簿深度(流动性过滤) SLIPPAGE_TOLERANCE=0.15 # 滑点容忍度(15%) ENTRY_THRESHOLD=0.35 # 入场阈值(YES token 价格 < 0.35 才买入) MAX_COST_PER_TRADE=1.2 # 单笔最大成本(超出则不买) # ============================================ # 时间窗口(本地时间,UTC+8) # ============================================ MONITOR_START_HOUR=9 # 监控开始时间(小时,小数形式) MONITOR_END_HOUR=9.9167 # 监控结束时间(9:55 = 9 + 55/60 = 9.9167) FALLBACK_START_HOUR=10 # Fallback 开始时间 FALLBACK_WINDOW_MINUTES=5 # Fallback 窗口长度(分钟) # ============================================ # 执行频率(秒) # ============================================ CHECK_INTERVAL=300 # 扫描间隔(300秒 = 5分钟) REPORT_INTERVAL=240 # 报告间隔(240秒 = 4分钟) # ============================================ # 缓存与重试 # ============================================ CACHE_TTL=3600 # 通用缓存时间(1小时) GAMMA_CACHE_TTL=300 # Gamma API 缓存(5分钟) CLOB_CACHE_TTL=30 # CLOB 订单簿缓存(30秒) MAX_CONCURRENT_REQUESTS=50 # 最大并发请求数 REQUEST_DELAY=0.05 # 请求间延迟(秒) MAX_RETRIES=3 # 最大重试次数(网络失败时) RETRY_DELAY=1.0 # 重试延迟(秒) # ============================================ # 文件路径 # ============================================ STATE_FILE=state.json # 状态文件(持仓、交易历史) CACHE_DIR=cache # 缓存目录 ``` --- ### 5.2 参数详细说明 / Parameter Reference #### 5.2.1 认证参数 / Authentication | 参数 | 类型 | 必填 | 说明 | 示例值 | 建议值 | |------|------|------|------|--------|--------| | `PRIVATE_KEY` | string | ✅ | EOA 钱包私钥( hexadecimal,带 `0x` 前缀) | `0xabc123...` | 使用**专用钱包**,不要用主钱包 | | `PROXY_WALLET` | string | ✅ | Polynomial 代理钱包地址(从网站导出) | `0x1234...` | 与 PRIVATE_KEY 对应的地址 | | `POLY_API_KEY` | string | ✅ | Polynomial L2 API Key(`pk_` 或 `sk_` 开头) | `pk_live_xxx` | 从 Settings → API Keys 创建 | | `POLY_API_SECRET` | string | ✅ | L2 API Secret | `sk_live_xxx` | 同上 | | `POLY_API_PASSPHRASE` | string | ✅ | 创建 API Key 时设置的密码 | `myPass123` | 记住它,不会显示第二次 | | `SIGNER_TYPE` | int | ✅ | 签名器类型:`1`=邮箱, `2`=Gnosis Safe | `0` | 普通钱包选 `2` | #### 5.2.2 交易参数 / Trading | 参数 | 类型 | 默认值 | 说明 | 建议值 | 风险提示 | |------|------|--------|------|--------|----------| | `TRADE_AMOUNT_USD` | float | `1.0` | 每笔订单目标金额(美元)。系统会自动计算 shares 数量 | `0.5` - `5.0` | 金额越大,潜在收益/损失都越高 | | `MIN_ORDERBOOK_SIZE` | float | `1.0` | 订单簿最小深度(需要至少有 $1.0 的流动性) | `1.0` | 太低可能滑点严重 | | `SLIPPAGE_TOLERANCE` | float | `0.15` (15%) | 滑点容忍度。如果 best_ask > 预期价格 × (1+滑点),则取消订单 | `0.05` - `0.20` | 保守交易选 5%,激进选 20% | | `ENTRY_THRESHOLD` | float | `0.35` | 入场阈值。YES token 价格必须低于此值才买入 | `0.30` - `0.50` | 太低可能错过机会,太高可能买贵 | | `MAX_COST_PER_TRADE` | float | `1.2` | 单笔最大成本(USD)。实际成本 = price × shares,如果超过此值则不买 | `1.5` - `2.0` | 用于控制极端滑点损失 | **公式示例**: ``` 假设 TRADE_AMOUNT_USD = 1.0, best_ask = 0.5 目标 shares = 1.0 / 0.5 = 2.0 shares 实际 cost = 0.5 × 2.0 = $1.0 OK 假设 best_ask = 0.6, 但 max_price = 0.6 × 1.15 = 0.69 如果 0.6 < 0.69 → 仍可买入 如果 0.7 > 0.69 → 跳过(滑点过大) ``` #### 5.2.3 时间窗口 / Time Windows | 参数 | 类型 | 默认值 | 说明 | 计算方式 | |------|------|--------|------|----------| | `MONITOR_START_HOUR` | float | `9` | 监控开始时间(小时) | `9` = 09:00 | | `MONITOR_END_HOUR` | float | `9.9167` | 监控结束时间 | `9 + 55/60 = 9.9167` = 09:55 | | `FALLBACK_START_HOUR` | float | `10` | Fallback 开始时间 | `10` = 10:00 | | `FALLBACK_WINDOW_MINUTES` | int | `5` | Fallback 窗口长度 | 10:00-10:04 | **时间逻辑**: - 09:00-09:55:正常扫描窗口(今日市场) - 10:00-10:04:Fallback 强制买入窗口(为今日未持仓的城市强行下单) - 09:55-10:00:空档期,不扫描 **为什么这样设置**: - 气象局通常在早上 08:00-09:00 发布当日天气预报 - 9:00 后市场已消化信息,不确定性降低 - 10:00 是最后买入机会,离 14:00 最高温还有 4 小时 - Fallback 窗口很短,避免重复下单 #### 5.2.4 执行频率 / Execution | 参数 | 类型 | 默认值 | 说明 | |------|------|--------|------| | `CHECK_INTERVAL` | int | `300` | 扫描周期(秒),每 5 分钟检查一次市场 | | `REPORT_INTERVAL` | int | `240` | 状态报告周期(秒),每 4 分钟打印持仓/PnL | **建议**: - 测试阶段:`CHECK_INTERVAL=60`(每分钟)以便快速看到效果 - 生产环境:`CHECK_INTERVAL=300`(5分钟)避免 API 限流 #### 5.2.5 缓存与重试 / Caching & Retry | 参数 | 类型 | 默认值 |