🚀 快速安装

复制以下命令并运行,立即安装此 Skill:

npx skills add https://skills.sh/affaan-m/everything-claude-code/x-api

💡 提示:需要 Node.js 和 NPM

X API

通过编程方式与 X(Twitter)进行交互,用于发布、读取、搜索和分析。

何时激活此技能

  • 用户想要以编程方式发布推文或帖子串
  • 从 X 读取时间线、提及或用户数据
  • 在 X 上搜索内容、趋势或对话
  • 构建 X 集成或机器人
  • 分析和互动跟踪
  • 用户说“发布到 X”、“发推”、“X API”或“Twitter API”

身份验证

OAuth 2.0 不记名令牌(仅应用)

最适合:读取密集型操作、搜索、公共数据。

# 环境设置
export X_BEARER_TOKEN="您的不记名令牌"
import os
import requests

bearer = os.environ["X_BEARER_TOKEN"]
headers = {"Authorization": f"Bearer {bearer}"}

# 搜索最近的推文
resp = requests.get(
    "https://api.x.com/2/tweets/search/recent",
    headers=headers,
    params={"query": "claude code", "max_results": 10}
)
tweets = resp.json()

OAuth 1.0a(用户上下文)

需要用于:发布推文、管理帐户、私信。

# 环境设置 — 使用前加载
export X_API_KEY="您的API密钥"
export X_API_SECRET="您的API密钥Secret"
export X_ACCESS_TOKEN="您的访问令牌"
export X_ACCESS_SECRET="您的访问令牌Secret"
import os
from requests_oauthlib import OAuth1Session

oauth = OAuth1Session(
    os.environ["X_API_KEY"],
    client_secret=os.environ["X_API_SECRET"],
    resource_owner_key=os.environ["X_ACCESS_TOKEN"],
    resource_owner_secret=os.environ["X_ACCESS_SECRET"],
)

核心操作

发布推文

resp = oauth.post(
    "https://api.x.com/2/tweets",
    json={"text": "来自 Claude Code 的问候"}
)
resp.raise_for_status()
tweet_id = resp.json()["data"]["id"]

发布帖子串

def post_thread(oauth, tweets: list[str]) -> list[str]:
    ids = []
    reply_to = None
    for text in tweets:
        payload = {"text": text}
        if reply_to:
            payload["reply"] = {"in_reply_to_tweet_id": reply_to}
        resp = oauth.post("https://api.x.com/2/tweets", json=payload)
        tweet_id = resp.json()["data"]["id"]
        ids.append(tweet_id)
        reply_to = tweet_id
    return ids

读取用户时间线

resp = requests.get(
    f"https://api.x.com/2/users/{user_id}/tweets",
    headers=headers,
    params={
        "max_results": 10,
        "tweet.fields": "created_at,public_metrics",
    }
)

搜索推文

resp = requests.get(
    "https://api.x.com/2/tweets/search/recent",
    headers=headers,
    params={
        "query": "from:affaanmustafa -is:retweet",
        "max_results": 10,
        "tweet.fields": "public_metrics,created_at",
    }
)

通过用户名获取用户

resp = requests.get(
    "https://api.x.com/2/users/by/username/affaanmustafa",
    headers=headers,
    params={"user.fields": "public_metrics,description,created_at"}
)

上传媒体并发布

# 媒体上传使用 v1.1 端点

# 步骤 1:上传媒体
media_resp = oauth.post(
    "https://upload.twitter.com/1.1/media/upload.json",
    files={"media": open("image.png", "rb")}
)
media_id = media_resp.json()["media_id_string"]

# 步骤 2:发布带媒体的推文
resp = oauth.post(
    "https://api.x.com/2/tweets",
    json={"text": "看看这个", "media": {"media_ids": [media_id]}}
)

速率限制

X API 的速率限制因端点、认证方法和帐户层级而异,并且随时间变化。请始终:

  • 在对代码中的假设进行硬编码之前,查阅最新的 X 开发者文档
  • 在运行时读取 x-rate-limit-remainingx-rate-limit-reset 头信息
  • 自动进行退避处理,而不是依赖代码中的静态表格
import time

remaining = int(resp.headers.get("x-rate-limit-remaining", 0))
if remaining < 5:
    reset = int(resp.headers.get("x-rate-limit-reset", 0))
    wait = max(0, reset - int(time.time()))
    print(f"即将达到速率限制。将在 {wait} 秒后重置")

错误处理

resp = oauth.post("https://api.x.com/2/tweets", json={"text": content})
if resp.status_code == 201:
    return resp.json()["data"]["id"]
elif resp.status_code == 429:
    reset = int(resp.headers["x-rate-limit-reset"])
    raise Exception(f"已达到速率限制。重置时间为 {reset}")
elif resp.status_code == 403:
    raise Exception(f"禁止访问:{resp.json().get('detail', '检查权限')}")
else:
    raise Exception(f"X API 错误 {resp.status_code}{resp.text}")

安全性

  • 切勿硬编码令牌。 使用环境变量或 .env 文件。
  • 切勿提交 .env 文件。 将其添加到 .gitignore
  • 如果令牌泄露,请及时轮换。 在 developer.x.com 重新生成。
  • 不需要写入权限时,使用只读令牌。
  • 安全存储 OAuth 密钥 — 不要放在源代码或日志中。

与内容引擎集成

使用 content-engine 技能生成符合平台特性的内容,然后通过 X API 发布:

  1. 使用内容引擎生成内容(X 平台格式)
  2. 验证长度(单条推文 280 字符)
  3. 使用上述模式通过 X API 发布
  4. 通过 public_metrics 跟踪互动情况

相关技能

  • content-engine — 为 X 生成符合平台特性的内容
  • crosspost — 在 X、LinkedIn 和其他平台间分发内容

📄 原始文档

完整文档(英文):

https://skills.sh/affaan-m/everything-claude-code/x-api

💡 提示:点击上方链接查看 skills.sh 原始英文文档,方便对照翻译。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。