twikit-mcp¶
Twitter/X MCP サーバー + CLI — API キー不要。
MCP サーバー — Claude(や MCP 対応の AI エージェント)がブラウザ cookies で Twitter/X を操作できます。同じ twikit-mcp バイナリは CLI としてもシェルスクリプトやデバッグに使えます。
0.1.33 の新機能¶
- 200 文字の切り捨てを廃止 —
get_timeline/search_tweets/get_user_tweets/get_bookmarks/get_list_tweets/get_scheduled_tweets/get_community_tweets/get_communities_timeline/search_community_tweetがツイート本文を 200 文字でカットしなくなりました。get_tweetとget_tweet_repliesもTweet.full_textを使用し、X のノートツイート(長文投稿、最大 4000 文字)も完全に取得できます。レスポンスサイズはcount引数で制御。(closes #97) get_article_previewの引用ツイート対応 — 入力が引用リツイートの場合、エラーが「これは引用ツイートで、記事ではありません。引用内容は get_tweet で読んでください」に変わり、汎用の "does not embed an article" は出なくなりました。
アップグレード:uv tool upgrade twikit-mcp(または pip install --upgrade twikit-mcp)。
0.1.32 の新機能¶
- ツイート返信の取得 — 新規
get_tweet_replies(tweet_id, cursor=None)ツールでツイートへのコメント / リプライを取得。vendored twikit 経由で X の TweetDetail GraphQL を使用、1 ページごとにnext_cursorで次ページ。リプライアイテムはget_user_tweets/get_timelineと同じコンパクト形式。(closes #94)
0.1.31 の新機能¶
- クライアント別インストール手順を文書化 — 新規インストールページで Claude Code / Claude Desktop / Cursor / Windsurf / Cline / opencode 6 クライアントへの登録手順を整理(クライアントあたり ≤ 12 行、設定ファイルパス + JSON スニペットのみ)。インストールコマンドは
uv tool install twikit-mcp統一、JSON の形はどのクライアントでも共通。(closes #92)
0.1.30 の新機能¶
- API ドキュメントページのローカライズ —
/zh/api/と/ja/api/で中国語 / 日本語の chrome(タイトル、イントロ、テーブルヘッダ、セクション名)を表示するようになりました。英語へフォールバックしません。ツールの docstring は Python ソースのまま(mkdocstringsと同じトレードオフ)。(closes #90)
0.1.29 の新機能¶
- Community と article-preview の信頼性向上 —
get_community/get_community_tweets/get_community_members/get_community_moderators/search_community_tweetがKeyError: 'rest_id'/IndexErrorでクラッシュしなくなりました。get_article_previewは syndication エンドポイントが 404(X が古い記事を削除)を返した場合、HTTPStatusErrorのスタックトレースを漏らさずクリーンなToolErrorを返します。_vendor/twikit/community.py+client.pyの全面.get()防御化。Issue #76 完了 —T_DRIFTは空集合になりました。(issue #76 parts 2 + 3)
0.1.28 の新機能¶
- List ツールの信頼性向上 —
get_list/get_list_tweets/get_list_members/get_list_subscribersがバーナー識別子で X にゲートされたレスポンス上でKeyError: 'created_at'/IndexError/Invalid list idでクラッシュしなくなりました。_vendor/twikit/list.py+client.pyの全面.get()防御化:欠損フィールドはNone/""/0、空 entries は空のResultを返します。live-smoke のT_LISTからT_DRIFTフォールバックも除去 — このクラスの再発を即座に検知できます。(issue #76 part 1)
0.1.27 の新機能¶
- ツイート動画のダウンロード(yt-dlp) — 新規 MCP ツール
download_tweet_videoと人間向け CLItwikit-mcp video <id>を追加。デフォルトでは~/Downloads/twikit-mcp/に保存し、既存のcookies.jsonで認証します。PATH にyt-dlpが必要(uv tool install yt-dlp)。ffmpegはbestvideo+bestaudioのような複数ストリームのマージが必要な format を渡したときだけ必要です。(closes #84)
0.1.26 の新機能¶
get_tweetで引用ツイートを公開 — レスポンスにis_quote_status/quoted_id/quoted_author/quoted_textが含まれるようになりました。引用リツイートの場合、引用元の作者と本文を即座に確認でき、エージェントが追加でget_tweetを呼ぶ必要がありません。これらは元から同じ GraphQL レスポンスに含まれていたものを取り出して公開しただけ。(closes #82)
0.1.25 の新機能¶
get_tweetに会話コンテキストを追加 — レスポンスにin_reply_to(リプライ元ツイートID)とconversation_id(スレッドのルートツイートID)が含まれるようになりました。エージェントは1つのリプライから親リンクをユーザーに尋ねることなくスレッド全体を遡れます。(closes #77)
0.1.24 の新機能¶
- Rich レンダリングのカード — 0.1.23 のターミナルカードを Rich が描画するようになりました。emoji と CJK の列幅計測が正確(
❤ 🔁行で右ボーダーがずれない)、ツイート / プロフィール / bio URL は OSC 8 でクリッカブル(iTerm2 / kitty / WezTerm / Windows Terminal / gnome-terminal ≥ 3.36 で cmd-クリックで開きます)。トレンドは真の Table レイアウトに。 - プレーンテキスト出力(非 TTY)は無変更:
| jq/> file/NO_COLOR=1の消費者にとってバイト安定が保たれます。
0.1.23 の新機能¶
- ASCII Twitter カード UI —
twikit-mcp tweet/user/tl/search/trendsがターミナルで box-drawing のカード表示になりました(太字の作者名、薄い表示の作成日時、本文 / カウント / URL の区切り線)。ファイルやパイプへリダイレクト、またはNO_COLOR=1を設定すると、従来通りのバイト安定なプレーンテキストへ自動フォールバック。出力例は CLI モード。
0.1.22 の新機能¶
- ヒューマン CLI サブコマンド — シェルから直接ツイート / プロフィール / タイムライン / 検索 / トレンドを読めます:
プレーンテキスト出力、ネイティブ Unicode、ちょうどいいデフォルト値。詳細は CLI モード。
- エンドツーエンド UTF-8 出力 — \uXXXX エスケープはもうありません。中文 / 日本語 / Ελληνικά / emoji はすべて読める形でツール出力されます。
- 三言語ドキュメントサイト — 今ご覧のこのページ。上部で言語を切り替えてください。
得られるもの¶
- 57 ツール — ツイート、ユーザー、リスト、コミュニティ、予約投稿+投票、DM、記事、検索、トレンド、通知。
- ブラウザ cookie 認証 — X セッションから
ct0とauth_tokenをコピーするだけ。 - 2 つのトランスポート、1 つのバイナリ — デフォルトは MCP サーバー(AI エージェント向け)、
twikit-mcp call <tool>は CLI(シェル向け)。 - vendored 版 twikit — プロジェクト固有の防御パッチ付き。
ドキュメント¶
- CLI モード — サブコマンド、型変換、終了コード、例。
- MCP ツール API — 自動生成のリファレンス:各ツールのシグネチャ、docstring、CLI 例(コードと同期)。
- 技術設計 — 内部実装(現在は中国語のみ — 翻訳歓迎)。
- twikit のベンダリング — すべてのパッチと対応する issue(現在は中国語のみ)。
- GitHub リポジトリ — README に三言語のフルインストール手順。
クイックインストール¶
# 1. X cookies を ~/.config/twitter-mcp/cookies.json に保存
mkdir -p ~/.config/twitter-mcp
cat > ~/.config/twitter-mcp/cookies.json <<'EOF'
{"ct0": "...", "auth_token": "..."}
EOF
chmod 600 ~/.config/twitter-mcp/cookies.json
# 2. インストール(日常利用に推奨)
uv tool install twikit-mcp
# 3. Claude Code に登録
claude mcp add twitter -s user \
-e "TWITTER_COOKIES=$HOME/.config/twitter-mcp/cookies.json" \
-- twikit-mcp
アップグレードは uv tool upgrade twikit-mcp;その他のオプション(uvx / pip / pipx)は GitHub README を参照。