jpskill.com
📦 その他 コミュニティ

minimax-music-playlist

ユーザーの音楽の好みや過去のフィードバックを分析し、その人に合った音楽プレイリストを多言語で生成したり、音楽の趣味を分析しておすすめの曲を提案したりするSkill。

📜 元の英語説明(参考)

Generate personalized music playlists by analyzing the user's music taste and generation feedback history. Triggers on any request involving playlist generation, music taste profiling, or personalized music recommendations. Supports multilingual triggers — match equivalent phrases in any language.

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

一言でいうと

ユーザーの音楽の好みや過去のフィードバックを分析し、その人に合った音楽プレイリストを多言語で生成したり、音楽の趣味を分析しておすすめの曲を提案したりするSkill。

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

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

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

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

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

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して minimax-music-playlist.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → minimax-music-playlist フォルダができる
  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-18
取得日時
2026-05-18
同梱ファイル
1

📖 Skill本文(日本語訳)

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

[Skill 名] minimax-music-playlist

MiniMax Music Playlist — パーソナライズされたプレイリストジェネレーター

ユーザーの音楽の好みをスキャンし、テイストプロファイルを作成し、パーソナライズされたプレイリストを生成し、アルバムカバーを作成します。このスキルは、エージェントと直接ユーザーの両方からの呼び出しに対応するように設計されており、コンテキストに合わせてインタラクションスタイルを調整します。

前提条件

  • mmx CLI — 音楽と画像の生成。インストール: npm install -g mmx-cli。認証: mmx auth login --api-key <key>
  • Python 3 — その場で記述するスキャン用スクリプト用(stdlibのみ、pipなし)。
  • オーディオプレーヤーmpvffplay、またはafplay(macOS内蔵)。

言語

ユーザーのメッセージからユーザーの言語を検出します。ユーザーに表示されるすべてのテキストは、ユーザーのプロンプトと同じ言語である必要があります — 言語を混ぜないでください。ユーザーが中国語で書いた場合、すべての出力(プロファイル概要、テーマの提案、プレイリスト計画、再生情報)は完全に中国語である必要があります。英語の場合、すべて英語である必要があります。

最高の品質を得るために、すべてのmmx生成プロンプトは英語である必要があります。 各曲の歌詞の言語は、ユーザーのUI言語ではなく、そのジャンルに従います(K-pop → 韓国語、J-pop → 日本語など)。


ワークフロー

1. ローカルの音楽アプリをスキャン → 2. テイストプロファイルを作成 → 3. プレイリストを計画
→ 4. 曲を生成 (mmx music) → 5. カバーを生成 (mmx image) → 6. 再生 → 7. 保存とフィードバック

ステップ1:音楽リスニングデータを収集する

利用可能なソースからユーザーのリスニングデータを収集します。

サポートされているソース:

ソース 方法 データ形式
Apple Music osascriptでMusic.appをクエリ(公式AppleScriptインターフェース) トラック名、アーティスト、アルバム、ジャンル、再生回数
Spotify ユーザーがSpotifyプライバシー設定から自分のデータをエクスポート ZIP内のJSONファイル(Streaming_History_Audio_*.json
手動入力 ユーザーが自分の好みを直接記述 フリーテキスト

Spotifyデータエクスポートフロー: Spotifyは有用なデータをローカルに保存しません。Spotifyのリスニング履歴を含めるには、まずユーザーがすでにSpotifyデータのエクスポートを持っているかどうかを確認します。

  1. 既存のエクスポートを検索: find ~ -maxdepth 4 -name "my_spotify_data.zip" -o -name "Streaming_History_Audio_*.json" 2>/dev/null
  2. 見つかった場合、ユーザーにそれを使用したいか尋ねます
  3. ZIPの場合、解凍してSpotify Extended Streaming History/Streaming_History_Audio_*.jsonを見つけます
  4. 見つからない場合、Spotifyのプライバシーページを開きます: open https://www.spotify.com/account/privacy/
  5. ユーザーにログインし、「データをダウンロード」までスクロールして「データをリクエスト」をクリックするように伝えます
  6. 今はSpotifyをスキップし、他のソースに進みます — データのエクスポートが届いた後(通常数日後)にプレイリストスキルを再実行できることをユーザーに伝えます

Spotifyデータ形式: エクスポートにはStreaming_History_Audio_YYYY.jsonファイル(年ごとに1つ)が含まれており、それぞれがリスニングイベントのJSON配列です。抽出する主要なフィールド:

  • master_metadata_album_artist_name — アーティスト名
  • master_metadata_track_name — トラック名
  • master_metadata_album_album_name — アルバム名
  • ms_played — 再生時間(ミリ秒単位)(重みとして使用: 長いほど強いシグナル)
  • ts — タイムスタンプ

ms_played < 30000(30秒未満、スキップされた可能性が高い)のエントリは除外します。 ip_addrやその他の機密フィールドは使用または保存しないでください。

各ソースから抽出するもの:

  • トラック名 + アーティスト名(主要なシグナル)
  • プレイリスト名とメンバーシップ(例:「Chinese Traditional」という名前のプレイリストはジャンルの好みを伝えます)
  • 再生回数またはストリーミング時間(利用可能な場合、頻繁に再生されるトラックを高く評価します)
  • シーン/ムードタグ(利用可能な場合)

アプローチ:

  1. Apple Musicが利用可能か確認します(osascriptクエリを試します)
  2. ユーザーが提供するSpotifyデータエクスポートZIPを持っているか尋ねます
  3. 利用可能なソースがない場合、ユーザーに手動で好みを記述するように依頼します

プライバシー規則: 生のトラックリストをユーザーに表示しないでください。集計された統計のみを表示してください。


ステップ2:テイストプロファイルを作成する

スキャンされたデータから、以下の項目をカバーするテイストプロファイルを作成します。

  • ジャンル分布 — ユーザーが聴くスタイル(例:J-pop 20%、R&B 15%、Classical 10%)
  • ムード傾向 — 感情的なトーンの好み(メランコリック、エネルギッシュ、穏やか、ロマンチックなど)
  • ボーカルの好み — 男性 vs 女性の声の比率
  • テンポの好み — スロー / モデレート / アップビート / ファストの分布
  • 言語分布 — zh、en、ja、koなど
  • トップアーティスト — 最も聴かれているアーティスト

アーティスト名からジャンル/ムードを推測する方法: ほとんどの生データには、ジャンルタグなしでアーティスト名とトラック名しかありません。これを充実させるには:

  1. <SKILL_DIR>/data/artist_genre_map.jsonにあるローカルマッピングテーブルでアーティストを検索します — このテーブルは、事前にマッピングされたジャンル、ボーカルタイプ、言語を持つ20,000の人気アーティストをカバーしています
  2. マッピングテーブルにないアーティストについては、MusicBrainz APIをクエリします: https://musicbrainz.org/ws/2/artist/?query=artist:<name>&fmt=json — レスポンスからジャンルタグを抽出します。レート制限(1リクエスト/秒)を遵守します — 再クエリを避けるために、結果を<SKILL_DIR>/data/artist_cache.jsonにキャッシュします
  3. MusicBrainzが結果を返さない場合、そのアーティストはスキップします

プロファイルのキャッシュ:

  • プロファイルを<SKILL_DIR>/data/taste_profile.jsonに保存します
  • 7日未満のプロファイルが存在する場合、それを再利用します(再スキャンオプションを提供します)
  • 古いまたは欠落している場合、再構築します

ユーザーに概要を表示する:

あなたの音楽プロファイル:
  ソース: Apple Music 230 | Spotify 140
  ジャンル: J-pop 20% | R&B 15% | Classical 10% | Indie Pop 9%
  ムード: メランコリック 25% | 穏やか 20% | ロマンチック 18%
  ボーカル: 女性 65% | 男性 35%
  トップアーティスト: フェイ・ウォン、坂本龍一、テイラー・スウィフト、ジェイ・チョウ、大貫妙子

明確なパラメーターを持つエージェントによって呼び出された場合、確認をスキップして続行します。 ユーザーによって直接呼び出された場合、続行する前にプロファイルが正しいか尋ねます。


ステップ3:プレイリストを計画する

生成する前に、ユーザーにテーマ/シーンを尋ねます。 これはワークフローにおける唯一の対話型ステップです。他のすべてのステップは自律的に実行されます。

呼び出し時にテーマがすでに提供されている場合(例:エージェントまたはユーザーが「深夜のチルプレイリストを生成して」と言った場合)、それを直接使用し、質問をスキップします。 そうでない場合、次のように尋ねます。

どのようなテーマで
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

MiniMax Music Playlist — Personalized Playlist Generator

Scan the user's music taste, build a taste profile, generate a personalized playlist, and create an album cover. This skill is designed for both agent and direct user invocation — adapt interaction style to context.

Prerequisites

  • mmx CLI — music & image generation. Install: npm install -g mmx-cli. Auth: mmx auth login --api-key <key>.
  • Python 3 — for scanning scripts you write on the fly (stdlib only, no pip).
  • Audio playermpv, ffplay, or afplay (macOS built-in).

Language

Detect the user's language from their message. All user-facing text must be in the same language as the user's prompt — do not mix languages. If the user writes in Chinese, all output (profile summary, theme suggestions, playlist plan, playback info) must be fully in Chinese. If in English, all in English.

All mmx generation prompts should be in English for best quality. Each song's lyrics language follows its genre (K-pop → Korean, J-pop → Japanese, etc.), NOT the user's UI language.


Workflow

1. Scan local music apps → 2. Build taste profile → 3. Plan playlist
→ 4. Generate songs (mmx music) → 5. Generate cover (mmx image) → 6. Play → 7. Save & feedback

Step 1: Gather Music Listening Data

Collect the user's listening data from available sources.

Supported sources:

Source Method Data format
Apple Music osascript to query Music.app (official AppleScript interface) Track name, artist, album, genre, play count
Spotify User exports their own data via Spotify Privacy Settings JSON files in ZIP (Streaming_History_Audio_*.json)
Manual input User describes their taste directly Free text

Spotify data export flow: Spotify does not store useful data locally. To include Spotify listening history, first check if the user already has a Spotify data export:

  1. Search for existing exports: find ~ -maxdepth 4 -name "my_spotify_data.zip" -o -name "Streaming_History_Audio_*.json" 2>/dev/null
  2. If found, ask the user if they want to use it
  3. If ZIP, unzip and locate Spotify Extended Streaming History/Streaming_History_Audio_*.json
  4. If not found, open the Spotify privacy page: open https://www.spotify.com/account/privacy/
  5. Tell the user to log in, scroll to "Download your data", and click "Request data"
  6. Skip Spotify for now and continue with other sources — tell the user they can re-run the playlist skill after the data export arrives (usually a few days)

Spotify data format: The export contains Streaming_History_Audio_YYYY.json files (one per year), each is a JSON array of listening events. Key fields to extract:

  • master_metadata_album_artist_name — artist name
  • master_metadata_track_name — track name
  • master_metadata_album_album_name — album name
  • ms_played — playback duration in milliseconds (use as weight: longer = stronger signal)
  • ts — timestamp

Filter out entries where ms_played < 30000 (less than 30 seconds, likely skipped). Do NOT use or store ip_addr or other sensitive fields.

What to extract from each source:

  • Track names + artist names (primary signal)
  • Playlist names and membership (e.g., a playlist named "Chinese Traditional" tells you genre preference)
  • Play counts or streaming duration if available (weight frequently played tracks higher)
  • Scene/mood tags if available

Approach:

  1. Check if Apple Music is available (try osascript query)
  2. Ask if the user has a Spotify data export ZIP to provide
  3. If no sources available, ask the user to describe their taste manually

Privacy rule: Never show raw track lists to the user. Only show aggregated stats.


Step 2: Build Taste Profile

From the scanned data, build a taste profile covering:

  • Genre distribution — what styles the user listens to (e.g., J-pop 20%, R&B 15%, Classical 10%)
  • Mood tendencies — emotional tone preferences (melancholic, energetic, calm, romantic, etc.)
  • Vocal preference — male vs female voice ratio
  • Tempo preference — slow / moderate / upbeat / fast distribution
  • Language distribution — zh, en, ja, ko, etc.
  • Top artists — most listened artists

How to infer genre/mood from artist names: Most raw data only has artist + track names without genre tags. To enrich this:

  1. Look up artists in the local mapping table at <SKILL_DIR>/data/artist_genre_map.json — this table covers 20,000 popular artists with pre-mapped genres, vocal type, and language
  2. For artists not in the mapping table, query the MusicBrainz API: https://musicbrainz.org/ws/2/artist/?query=artist:<name>&fmt=json — extract genre tags from the response; respect rate limit (1 req/sec) — cache results to <SKILL_DIR>/data/artist_cache.json to avoid re-querying
  3. If MusicBrainz returns no results, skip the artist

Profile caching:

  • Save profile to <SKILL_DIR>/data/taste_profile.json
  • If a profile less than 7 days old exists, reuse it (offer rescan option)
  • If older or missing, rebuild

Show user a summary:

Your Music Profile:
  Sources: Apple Music 230 | Spotify 140
  Genres: J-pop 20% | R&B 15% | Classical 10% | Indie Pop 9%
  Moods: Melancholic 25% | Calm 20% | Romantic 18%
  Vocals: Female 65% | Male 35%
  Top artists: Faye Wong, Ryuichi Sakamoto, Taylor Swift, Jay Chou, Taeko Onuki

If invoked by an agent with clear parameters, skip the confirmation and proceed. If invoked by a user directly, ask if the profile looks right before continuing.


Step 3: Plan Playlist

Ask the user for a theme/scene before generating. This is the one interactive step in the workflow. All other steps run autonomously.

If the theme was already provided in the invocation (e.g., the agent or user said "generate a late night chill playlist"), use it directly and skip the question. Otherwise, ask:

What theme would you like for your playlist? Here are some suggestions:

- "Late night chill" — relaxing slow songs
- "Commute" — upbeat and energizing
- "Rainy day" — melancholic & cozy
- "Surprise me" — random based on your taste

Or tell me your own vibe!

Once the user picks a theme, proceed automatically through generation, cover, playback, and saving — no further confirmations needed.

Determine playlist parameters:

  • Theme/mood — from user input, or default to top mood from profile
  • Song count — from user input, or default to 5
  • Genre mix — weighted by profile, with variety

Per-song lyrics language follows genre:

Genre Lyrics language
K-pop, Korean R&B/ballad Korean
J-pop, city pop, J-rock Japanese
C-pop, Chinese-style, Mandopop Chinese
Western pop/indie/rock/jazz/R&B English
Latin pop, bossa nova Spanish/Portuguese
Instrumental, lo-fi, ambient No lyrics (--instrumental)

Embed language naturally into the mmx prompt via vocal description:

  • Good: "A melancholy Chinese R&B ballad with a gentle introspective male voice, electric piano, bass, slow tempo"
  • Bad: "R&B ballad, melancholy... sung in Chinese"

Show the playlist plan before generating. Display each song with two lines: the first line shows genre, mood, and vocal/language tag; the second line shows a short description of the song. All user-facing text (plan, descriptions, moods, labels) must be in the same language as the user's prompt. Only the actual --prompt passed to mmx should be in English — this is internal and should NOT be shown to the user. Example:

Playlist Plan: Late Night Chill (5 songs)

1. Neo-soul R&B — introspective  English/male vocal
   A mellow neo-soul R&B ballad with warm baritone, electric piano, smooth bass

2. Lo-fi hip-hop — dreamy  Instrumental
   Dreamy lo-fi with sampled piano, vinyl crackle, soft electronic drums

3. Smooth jazz — romantic  English/female vocal
   Silky female voice, saxophone, piano, romantic starlit night

4. Indie folk — melancholic  English/male vocal
   Tender male voice, acoustic guitar, harmonica, quiet solitude

5. Ambient electronic — calm  Instrumental
   Soft synth pads, gentle arpeggios, dreamy atmosphere

After showing the plan, proceed directly to generation — no confirmation needed. The user has already chosen the theme; the plan is shown for transparency, not approval.


Step 4: Generate Songs

Use mmx music generate to create all songs. Generate concurrently (up to 5 in parallel).

# Example: 5 songs in parallel
mmx music generate --prompt "<english_prompt_1>" --lyrics-optimizer \
  --out ~/Music/minimax-gen/playlists/<name>/01_desc.mp3 --quiet --non-interactive &
mmx music generate --prompt "<english_prompt_2>" --instrumental \
  --out ~/Music/minimax-gen/playlists/<name>/02_desc.mp3 --quiet --non-interactive &
# ... more songs ...
wait

Key flags:

  • --lyrics-optimizer — auto-generate lyrics from prompt (for vocal tracks)
  • --instrumental — no vocals
  • --vocals "<description>" — vocal style (e.g., "warm Chinese male baritone")
  • --genre, --mood, --tempo, --instruments — fine-grained control
  • --quiet --non-interactive — suppress interactive output for batch mode
  • --out <path> — save to file

File naming: <NN>_<short_desc>.mp3 (e.g., 01_rnb_midnight.mp3)

Output directory: ~/Music/minimax-gen/playlists/<playlist_name>/

If a song fails, retry once before skipping. Log the error and continue with the rest.


Step 5: Generate Album Cover

Generate the album cover concurrently with the songs (Step 4), not after. Launch the mmx image generate call in parallel with the song generation calls.

Craft a prompt that reflects the playlist's theme, mood, and genre mix. The image should feel like an album cover — artistic, evocative, not literal.

mmx image generate \
  --prompt "<cover description based on playlist theme and mood>" \
  --aspect-ratio 1:1 \
  --out-dir ~/Music/minimax-gen/playlists/<playlist_name>/ \
  --out-prefix cover \
  --quiet

Prompt guidance:

  • Abstract/artistic style works best for album covers
  • Reference the dominant mood and genre (e.g., "dreamy late-night cityscape, neon reflections, lo-fi aesthetic")
  • Do NOT include text or song titles in the image prompt
  • Aspect ratio should be 1:1 (square, standard album cover)

Step 6: Playback

Detect an available player and play the playlist in order:

Player Command Controls
mpv mpv --no-video <file> q skip, Space pause, arrows seek
ffplay ffplay -nodisp -autoexit <file> q skip
afplay afplay <file> Ctrl+C skip

Play all .mp3 files in the playlist directory in filename order. Only play the songs generated in this session — if the directory has old files from a previous run, clean them out first or filter by the known filenames. If no player is found, just show the file paths.


Step 7: Save & Feedback

Save playlist metadata to <playlist_dir>/playlist.json:

{
  "name": "Late Night Chill",
  "theme": "late night chill",
  "created_at": "2026-04-11T22:00:00",
  "song_count": 5,
  "cover": "cover_001.png",
  "songs": [
    {"index": 1, "filename": "01_rnb_midnight.mp3", "prompt": "...", "rating": null}
  ]
}

If the user is present, ask for feedback (per-song or overall). Update the taste profile's feedback section with liked/disliked genres and prompts to improve future playlists.


Replaying Playlists

If asked to play a previous playlist: ls ~/Music/minimax-gen/playlists/, show available ones, and play the selected one.


Notes

  • Agent vs user invocation: The theme/scene question (Step 3) is the single interactive touchpoint. If the theme is already provided in the invocation, skip the question. Everything else runs autonomously.
  • No hardcoded scripts: Write scanning/analysis scripts on the fly as needed. Use Python stdlib only. Cache results to avoid redundant work.
  • Skill directory: <SKILL_DIR> = the directory containing this SKILL.md file. Data/cache files go in <SKILL_DIR>/data/.
  • All mmx prompts in English for best generation quality.