jpskill.com
💬 コミュニケーション コミュニティ 🟡 少し慣れが必要 👤 幅広いユーザー

💬 Spotify

spotify

Spotifyで音楽を再生したり、曲を検索したり

⏱ 社内アナウンス文 30分 → 3分

📺 まず動画で見る(YouTube)

▶ 【最新版】Claude(クロード)完全解説!20以上の便利機能をこの動画1本で全て解説 ↗

※ jpskill.com 編集部が参考用に選んだ動画です。動画の内容と Skill の挙動は厳密には一致しないことがあります。

📜 元の英語説明(参考)

Spotify: play, search, queue, manage playlists and devices.

🇯🇵 日本人クリエイター向け解説

一言でいうと

Spotifyで音楽を再生したり、曲を検索したり

※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o spotify.zip https://jpskill.com/download/1215.zip && unzip -o spotify.zip && rm spotify.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/1215.zip -OutFile "$d\spotify.zip"; Expand-Archive "$d\spotify.zip" -DestinationPath $d -Force; ri "$d\spotify.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して spotify.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → spotify フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-17
取得日時
2026-05-17
同梱ファイル
1

💬 こう話しかけるだけ — サンプルプロンプト

  • Spotify の使い方を教えて
  • Spotify で何ができるか具体例で見せて
  • Spotify を初めて使う人向けにステップを案内して

これをClaude Code に貼るだけで、このSkillが自動発動します。

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

Spotify

Hermes Spotify ツールセット(7つのツール)を介して、ユーザーのSpotifyアカウントを制御します。セットアップガイド:https://hermes-agent.nousresearch.com/docs/user-guide/features/spotify

このスキルを使用するタイミング

ユーザーが「Xを再生して」、「一時停止」、「スキップ」、「Xをキューに追加」、「何が再生されているの」、「Xを検索して」、「私のXプレイリストに追加して」、「プレイリストを作成して」、「これをライブラリに保存して」などの発言をした場合。

7つのツール

  • spotify_playback — 再生、一時停止、次へ、前へ、シーク、リピート設定、シャッフル設定、音量設定、状態取得、現在再生中の曲取得、最近再生した曲
  • spotify_devices — リスト、転送
  • spotify_queue — 取得、追加
  • spotify_search — カタログを検索
  • spotify_playlists — リスト、取得、作成、アイテム追加、アイテム削除、詳細更新
  • spotify_albums — 取得、トラック
  • spotify_librarykind: "tracks"|"albums" でリスト/保存/削除

再生を変更するアクションにはSpotify Premiumが必要です。検索/ライブラリ/プレイリスト操作はFreeプランで動作します。

規範的なパターン(ツール呼び出しを最小限に抑える)

「<アーティスト/トラック/アルバム>を再生」

1回の検索後、URIで再生します。ユーザーがオプションを尋ねない限り、検索結果をループして説明しないでください。

spotify_search({"query": "miles davis kind of blue", "types": ["album"], "limit": 1})
→ アルバムURI spotify:album:1weenld61qoidwYuZ1GESA を取得
spotify_playback({"action": "play", "context_uri": "spotify:album:1weenld61qoidwYuZ1GESA"})

「<アーティスト>の曲を再生」(特定の曲なし)の場合、types: ["artist"] を優先し、アーティストのコンテキストURIを再生してください。Spotifyがスマートシャッフルを処理します。ユーザーが「その曲」または「そのトラック」と言った場合は、types: ["track"] で検索し、uris: [track_uri] を渡して再生してください。

「何が再生されているの?」 / 「何を聞いているの?」

単一の呼び出し — get_currently_playing の後に get_state を連結しないでください。

spotify_playback({"action": "get_currently_playing"})

204/空(is_playing: false)が返された場合は、何も再生されていないことをユーザーに伝えてください。再試行しないでください。

「一時停止」 / 「スキップ」 / 「音量50」

直接アクション、事前検査は不要です。

spotify_playback({"action": "pause"})
spotify_playback({"action": "next"})
spotify_playback({"action": "set_volume", "volume_percent": 50})

「私の<プレイリスト名>プレイリストに追加」

  1. spotify_playlists list で名前からプレイリストIDを見つける
  2. トラックURIを取得する(現在再生中の曲から、または検索から)
  3. プレイリストIDとURIで spotify_playlists add_items を呼び出す
spotify_playlists({"action": "list"})
→ "Late Night Jazz" = 37i9dQZF1DX4wta20PHgwo を発見
spotify_playback({"action": "get_currently_playing"})
→ 現在のトラックURI = spotify:track:0DiWol3AO6WpXZgp0goxAV
spotify_playlists({"action": "add_items",
                   "playlist_id": "37i9dQZF1DX4wta20PHgwo",
                   "uris": ["spotify:track:0DiWol3AO6WpXZgp0goxAV"]})

「Xというプレイリストを作成して、最後に再生した3曲を追加して」

spotify_playback({"action": "recently_played", "limit": 3})
spotify_playlists({"action": "create", "name": "Focus 2026"})
→ レスポンスでplaylist_idが返される
spotify_playlists({"action": "add_items", "playlist_id": <id>, "uris": [<3 uris>]})

「保存 / 保存解除 / これは保存されている?」

適切な kindspotify_library を使用してください。

spotify_library({"kind": "tracks", "action": "save", "uris": ["spotify:track:..."]})
spotify_library({"kind": "albums", "action": "list", "limit": 50})

「再生を私の<デバイス>に転送」

spotify_devices({"action": "list"})
→ 名前/タイプを一致させてdevice_idを選択
spotify_devices({"action": "transfer", "device_id": "<id>", "play": true})

致命的な障害モード

いずれかの再生アクションで403 Forbidden — No active device foundが発生した場合、Spotifyがどこでも実行されていないことを意味します。ユーザーに「まず、スマートフォン/デスクトップ/ウェブプレーヤーでSpotifyを開き、任意のトラックを数秒間再生してから、再試行してください」と伝えてください。ツール呼び出しを盲目的に再試行しないでください — 同じように失敗します。spotify_devices list を呼び出して確認できます。空のリストはアクティブなデバイスがないことを意味します。

403 Forbidden — Premium requiredは、ユーザーがFreeプランで再生を変更しようとしたことを意味します。再試行しないでください。このアクションにはPremiumが必要であることを伝えてください。読み取り操作(検索、プレイリスト、ライブラリ、get_state)は引き続き機能します。

get_currently_playing204 No Contentはエラーではありません — 何も再生されていないことを意味します。ツールは is_playing: false を返します。それをユーザーに報告するだけです。

429 Too Many Requests = レート制限です。待ってから一度再試行してください。繰り返し発生する場合は、ループしているため停止してください。

再試行後に 401 Unauthorized — リフレッシュトークンが取り消されました。ユーザーに hermes auth spotify を再度実行するよう伝えてください。

URIとIDの形式

Spotifyは3つの交換可能なID形式を使用します。ツールはこれらすべてを受け入れ、正規化します。

  • URI: spotify:track:0DiWol3AO6WpXZgp0goxAV (推奨)
  • URL: https://open.spotify.com/track/0DiWol3AO6WpXZgp0goxAV
  • ベアID: 0DiWol3AO6WpXZgp0goxAV

不明な場合は、完全なURIを使用してください。検索結果は uri フィールドにURIを返します — それらを直接渡してください。

エンティティタイプ: trackalbumartistplaylistshowepisode。アクションに適切なタイプを使用してください — spotify_playback.playcontext_uri にアルバム/プレイリスト/アーティストを期待し、uris にはトラックURIの配列を期待します。

してはいけないこと

  • すべてのアクションの前に get_state を呼び出さないでください。 Spotifyは事前検査なしで再生/一時停止/スキップを受け入れます。ユーザーが「何が再生されているの」と尋ねた場合、またはデバイス/トラックについて推論する必要がある場合にのみ状態を検査してください。
  • 尋ねられない限り、検索結果を説明しないでください。 ユーザーが「Xを再生して」と言った場合、検索し、上位のURIを取得して再生してください。間違っていれば、ユーザーがそれを聞けばわかります。
  • 403 Premium required または 403 No active device で再試行しないでください。 これらはユーザーのアクションがあるまで永続的です。
  • spotify_search を使用して名前でプレイリストを検索しないでください — それは公開されているSpotifyカタログを検索します。ユーザーのプレイリストは spotify_playlists list から取得されます。
  • spotify_librarykind: "tracks" とアルバムURIを混同しないでください(またはその逆)。ツールはIDを正規化しますが、APIエンドポイントは異なります。
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

Spotify

Control the user's Spotify account via the Hermes Spotify toolset (7 tools). Setup guide: https://hermes-agent.nousresearch.com/docs/user-guide/features/spotify

When to use this skill

The user says something like "play X", "pause", "skip", "queue up X", "what's playing", "search for X", "add to my X playlist", "make a playlist", "save this to my library", etc.

The 7 tools

  • spotify_playback — play, pause, next, previous, seek, set_repeat, set_shuffle, set_volume, get_state, get_currently_playing, recently_played
  • spotify_devices — list, transfer
  • spotify_queue — get, add
  • spotify_search — search the catalog
  • spotify_playlists — list, get, create, add_items, remove_items, update_details
  • spotify_albums — get, tracks
  • spotify_library — list/save/remove with kind: "tracks"|"albums"

Playback-mutating actions require Spotify Premium; search/library/playlist ops work on Free.

Canonical patterns (minimize tool calls)

"Play <artist/track/album>"

One search, then play by URI. Do NOT loop through search results describing them unless the user asked for options.

spotify_search({"query": "miles davis kind of blue", "types": ["album"], "limit": 1})
→ got album URI spotify:album:1weenld61qoidwYuZ1GESA
spotify_playback({"action": "play", "context_uri": "spotify:album:1weenld61qoidwYuZ1GESA"})

For "play some <artist>" (no specific song), prefer types: ["artist"] and play the artist context URI — Spotify handles smart shuffle. If the user says "the song" or "that track", search types: ["track"] and pass uris: [track_uri] to play.

"What's playing?" / "What am I listening to?"

Single call — don't chain get_state after get_currently_playing.

spotify_playback({"action": "get_currently_playing"})

If it returns 204/empty (is_playing: false), tell the user nothing is playing. Don't retry.

"Pause" / "Skip" / "Volume 50"

Direct action, no preflight inspection needed.

spotify_playback({"action": "pause"})
spotify_playback({"action": "next"})
spotify_playback({"action": "set_volume", "volume_percent": 50})

"Add to my <playlist name> playlist"

  1. spotify_playlists list to find the playlist ID by name
  2. Get the track URI (from currently playing, or search)
  3. spotify_playlists add_items with the playlist_id and URIs
spotify_playlists({"action": "list"})
→ found "Late Night Jazz" = 37i9dQZF1DX4wta20PHgwo
spotify_playback({"action": "get_currently_playing"})
→ current track uri = spotify:track:0DiWol3AO6WpXZgp0goxAV
spotify_playlists({"action": "add_items",
                   "playlist_id": "37i9dQZF1DX4wta20PHgwo",
                   "uris": ["spotify:track:0DiWol3AO6WpXZgp0goxAV"]})

"Create a playlist called X and add the last 3 songs I played"

spotify_playback({"action": "recently_played", "limit": 3})
spotify_playlists({"action": "create", "name": "Focus 2026"})
→ got playlist_id back in response
spotify_playlists({"action": "add_items", "playlist_id": <id>, "uris": [<3 uris>]})

"Save / unsave / is this saved?"

Use spotify_library with the right kind.

spotify_library({"kind": "tracks", "action": "save", "uris": ["spotify:track:..."]})
spotify_library({"kind": "albums", "action": "list", "limit": 50})

"Transfer playback to my <device>"

spotify_devices({"action": "list"})
→ pick the device_id by matching name/type
spotify_devices({"action": "transfer", "device_id": "<id>", "play": true})

Critical failure modes

403 Forbidden — No active device found on any playback action means Spotify isn't running anywhere. Tell the user: "Open Spotify on your phone/desktop/web player first, start any track for a second, then retry." Don't retry the tool call blindly — it will fail the same way. You can call spotify_devices list to confirm; an empty list means no active device.

403 Forbidden — Premium required means the user is on Free and tried to mutate playback. Don't retry; tell them this action needs Premium. Reads still work (search, playlists, library, get_state).

204 No Content on get_currently_playing is NOT an error — it means nothing is playing. The tool returns is_playing: false. Just report that to the user.

429 Too Many Requests = rate limit. Wait and retry once. If it keeps happening, you're looping — stop.

401 Unauthorized after a retry — refresh token revoked. Tell the user to run hermes auth spotify again.

URI and ID formats

Spotify uses three interchangeable ID formats. The tools accept all three and normalize:

  • URI: spotify:track:0DiWol3AO6WpXZgp0goxAV (preferred)
  • URL: https://open.spotify.com/track/0DiWol3AO6WpXZgp0goxAV
  • Bare ID: 0DiWol3AO6WpXZgp0goxAV

When in doubt, use full URIs. Search results return URIs in the uri field — pass those directly.

Entity types: track, album, artist, playlist, show, episode. Use the right type for the action — spotify_playback.play with a context_uri expects album/playlist/artist; uris expects an array of track URIs.

What NOT to do

  • Don't call get_state before every action. Spotify accepts play/pause/skip without preflight. Only inspect state when the user asked "what's playing" or you need to reason about device/track.
  • Don't describe search results unless asked. If the user said "play X", search, grab the top URI, play it. They'll hear it's wrong if it's wrong.
  • Don't retry on 403 Premium required or 403 No active device. Those are permanent until user action.
  • Don't use spotify_search to find a playlist by name — that searches the public Spotify catalog. User playlists come from spotify_playlists list.
  • Don't mix kind: "tracks" with album URIs in spotify_library (or vice versa). The tool normalizes IDs but the API endpoint differs.