
关于
X/Twitter API 集成,用于发推、线程、读取时间线、搜索和分析。涵盖 OAuth 认证模式、速率限制和平台原生内容发布。适用于以编程方式与 X 交互。
name: x-api description: X/Twitter API 集成,用于发布推文、线程、读取时间线、搜索和分析。涵盖 OAuth 认证模式、速率限制和平台原生内容发布。当用户想要以编程方式与 X 交互时使用。 origin: ECC
X API
易漂移技能。 X API 端点、访问层级、配额和写入权限经常变化。在引用速率限制或实现发布/搜索流程之前,请验证当前开发者文档和账户访问权限。
以编程方式与 X (Twitter) 交互,用于发布、读取、搜索和分析。
何时激活
- 用户想要以编程方式发布推文或线程
- 从 X 读取时间线、提及或用户数据
- 在 X 上搜索内容、趋势或对话
- 构建 X 集成或机器人
- 分析和互动跟踪
- 用户说"发布到 X"、"推文"、"X API"或"Twitter API"
认证
OAuth 2.0 Bearer Token(仅应用)
适用于:读取密集型操作、搜索、公开数据。
# Environment setup
export X_BEARER_TOKEN="your-bearer-token"
import os
import requests
bearer = os.environ["X_BEARER_TOKEN"]
headers = {"Authorization": f"Bearer {bearer}"}
# Search recent tweets
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(用户上下文)
必需用于:发布推文、管理账户、私信和任何写入流程。
# Environment setup — source before use
export X_CONSUMER_KEY="your-consumer-key"
export X_CONSUMER_SECRET="your-consumer-secret"
export X_ACCESS_TOKEN="your-access-token"
export X_ACCESS_TOKEN_SECRET="your-access-token-secret"
旧版别名如 X_API_KEY、X_API_SECRET 和 X_ACCESS_SECRET 可能存在于旧设置中。在记录或连接新流程时,优先使用 X_CONSUMER_* 和 X_ACCESS_TOKEN_SECRET 名称。
import os
from requests_oauthlib import OAuth1Session
oauth = OAuth1Session(
os.environ["X_CONSUMER_KEY"],
client_secret=os.environ["X_CONSUMER_SECRET"],
resource_owner_key=os.environ["X_ACCESS_TOKEN"],
resource_owner_secret=os.environ["X_ACCESS_TOKEN_SECRET"],
)
核心操作
发布推文
resp = oauth.post(
"https://api.x.com/2/tweets",
json={"text": "Hello from 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/tweets/search/recent",
headers=headers,
params={
"query": "from:affaanmustafa -is:retweet -is:reply",
"max_results": 25,
"tweet.fields": "created_at,public_metrics",
}
)
voice_samples = resp.json()
通过用户名获取用户
resp = requests.get(
"https://api.x.com/2/users/by/username/affaanmustafa",
headers=headers,
params={"user.fields": "public_metrics,description,created_at"}
)
上传媒体并发布
# Media upload uses v1.1 endpoint
# Step 1: Upload media
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"]
# Step 2: Post with media
resp = oauth.post(
"https://api.x.com/2/tweets",
json={"text": "Check this out", "media": {"media_ids": [media_id]}}
)
速率限制
X API 速率限制因端点、认证方式和账户层级而异,且会随时间变化。始终:
- 在硬编码假设之前检查当前 X 开发者文档
- 在运行时读取
x-rate-limit-remaining和x-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"Rate limit approaching, waiting {wait}s")
time.sleep(wait)
兼容工具
Claude CodeCursor
标签
数据分析

