Skip to content
Web API •References / Tracks / Get Recommendations

Get Recommendations

Recommendations are generated based on the available information for a given seed entity and matched against similar artists and tracks. If there is sufficient information about the provided seeds, a list of tracks will be returned together with pool size details.

For artists and tracks that are very new or obscure there might not be enough data to generate a list of tracks.

Important policy note

Request

  • limit
    integer

    The target size of the list of recommended tracks. For seeds with unusually small pools or when highly restrictive filtering is applied, it may be impossible to generate the requested number of recommended tracks. Debugging information for such cases is available in the response. Default: 20. Minimum: 1. Maximum: 100.

    Default: limit=20Range: 1 - 100Example: limit=10
  • market
    string

    An ISO 3166-1 alpha-2 country code. If a country code is specified, only content that is available in that market will be returned.
    If a valid user access token is specified in the request header, the country associated with the user account will take priority over this parameter.
    Note: If neither market or user country are provided, the content is considered unavailable for the client.
    Users can view the country that is associated with their account in the account settings.

    Example: market=ES
  • seed_artists
    string
    Required

    A comma separated list of Spotify IDs for seed artists. Up to 5 seed values may be provided in any combination of seed_artists, seed_tracks and seed_genres.
    Note: only required if seed_genres and seed_tracks are not set.

    Example: seed_artists=4NHQUGzhtTLFvgF5SZesLK
  • seed_genres
    string
    Required

    A comma separated list of any genres in the set of available genre seeds. Up to 5 seed values may be provided in any combination of seed_artists, seed_tracks and seed_genres.
    Note: only required if seed_artists and seed_tracks are not set.

    Example: seed_genres=classical,country
  • seed_tracks
    string
    Required

    A comma separated list of Spotify IDs for a seed track. Up to 5 seed values may be provided in any combination of seed_artists, seed_tracks and seed_genres.
    Note: only required if seed_artists and seed_genres are not set.

    Example: seed_tracks=0c6xIDDpzE81m2q797ordA
  • min_acousticness
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_acousticness
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_acousticness
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_danceability
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_danceability
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_danceability
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_duration_ms
    integer

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

  • max_duration_ms
    integer

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

  • target_duration_ms
    integer

    Target duration of the track (ms)

  • min_energy
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_energy
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_energy
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_instrumentalness
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_instrumentalness
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_instrumentalness
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_key
    integer

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 11
  • max_key
    integer

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 11
  • target_key
    integer

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 11
  • min_liveness
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_liveness
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_liveness
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_loudness
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

  • max_loudness
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

  • target_loudness
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

  • min_mode
    integer

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_mode
    integer

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_mode
    integer

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_popularity
    integer

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 100
  • max_popularity
    integer

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 100
  • target_popularity
    integer

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 100
  • min_speechiness
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_speechiness
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_speechiness
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1
  • min_tempo
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

  • max_tempo
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

  • target_tempo
    number

    Target tempo (BPM)

  • min_time_signature
    integer

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Maximum value: 11
  • max_time_signature
    integer

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

  • target_time_signature
    integer

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

  • min_valence
    number

    For each tunable track attribute, a hard floor on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.

    Range: 0 - 1
  • max_valence
    number

    For each tunable track attribute, a hard ceiling on the selected track attribute’s value can be provided. See tunable track attributes below for the list of available options. For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.

    Range: 0 - 1
  • target_valence
    number

    For each of the tunable track attributes (below) a target value may be provided. Tracks with the attribute values nearest to the target values will be preferred. For example, you might request target_energy=0.6 and target_danceability=0.8. All target values will be weighed equally in ranking results.

    Range: 0 - 1

Response

A set of recommendations

  • Required

    An array of recommendation seed objects.

    • afterFilteringSize
      integer

      The number of tracks available after min_* and max_* filters have been applied.

    • afterRelinkingSize
      integer

      The number of tracks available after relinking for regional availability.

    • href
      string

      A link to the full track or artist data for this seed. For tracks this will be a link to a Track Object. For artists a link to an Artist Object. For genre seeds, this value will be null.

    • id
      string

      The id used to select this seed. This will be the same as the string used in the seed_artists, seed_tracks or seed_genres parameter.

    • initialPoolSize
      integer

      The number of recommended tracks available for this seed.

    • type
      string

      The entity type of this seed. One of artist, track or genre.

  • Required

    An array of track object (simplified) ordered according to the parameters supplied.

    • The album on which the track appears. The album object includes a link in href to full information about the album.

      • album_type
        string
        Required

        The type of the album.

        Allowed values: "album", "single", "compilation"Example: "compilation"
      • total_tracks
        integer
        Required

        The number of tracks in the album.

        Example: 9
      • available_markets
        array of strings
        Required

        The markets in which the album is available: ISO 3166-1 alpha-2 country codes. NOTE: an album is considered available in a market when at least 1 of its tracks is available in that market.

        Example: ["CA","BR","IT"]
      • Required

        Known external URLs for this album.

      • href
        string
        Required

        A link to the Web API endpoint providing full details of the album.

      • id
        string
        Required

        The Spotify ID for the album.

        Example: "2up3OPMp9Tb4dAKM2erWXQ"
      • Required

        The cover art for the album in various sizes, widest first.

        • url
          string
          Required

          The source URL of the image.

          Example: "https://i.scdn.co/image/ab67616d00001e02ff9ca10b55ce82ae553c8228"
        • height
          integer
          Required
          Nullable

          The image height in pixels.

          Example: 300
        • width
          integer
          Required
          Nullable

          The image width in pixels.

          Example: 300
      • name
        string
        Required

        The name of the album. In case of an album takedown, the value may be an empty string.

      • release_date
        string
        Required

        The date the album was first released.

        Example: "1981-12"
      • release_date_precision
        string
        Required

        The precision with which release_date value is known.

        Allowed values: "year", "month", "day"Example: "year"
      • Included in the response when a content restriction is applied.

        • reason
          string

          The reason for the restriction. Albums may be restricted if the content is not available in a given market, to the user's subscription type, or when the user's account is set to not play explicit content. Additional reasons may be added in the future.

          Allowed values: "market", "product", "explicit"
      • type
        string
        Required

        The object type.

        Allowed values: "album"
      • uri
        string
        Required

        The Spotify URI for the album.

        Example: "spotify:album:2up3OPMp9Tb4dAKM2erWXQ"
      • Required

        The artists of the album. Each artist object includes a link in href to more detailed information about the artist.

        • Known external URLs for this artist.

        • href
          string

          A link to the Web API endpoint providing full details of the artist.

        • id
          string

          The Spotify ID for the artist.

        • name
          string

          The name of the artist.

        • type
          string

          The object type.

          Allowed values: "artist"
        • uri
          string

          The Spotify URI for the artist.

    • The artists who performed the track. Each artist object includes a link in href to more detailed information about the artist.

      • Known external URLs for this artist.

      • href
        string

        A link to the Web API endpoint providing full details of the artist.

      • id
        string

        The Spotify ID for the artist.

      • name
        string

        The name of the artist.

      • type
        string

        The object type.

        Allowed values: "artist"
      • uri
        string

        The Spotify URI for the artist.

    • available_markets
      array of strings

      A list of the countries in which the track can be played, identified by their ISO 3166-1 alpha-2 code.

    • disc_number
      integer

      The disc number (usually 1 unless the album consists of more than one disc).

    • duration_ms
      integer

      The track length in milliseconds.

    • explicit
      boolean

      Whether or not the track has explicit lyrics ( true = yes it does; false = no it does not OR unknown).

    • Known external IDs for the track.

    • Known external URLs for this track.

    • href
      string

      A link to the Web API endpoint providing full details of the track.

    • id
      string

      The Spotify ID for the track.

    • is_playable
      boolean

      Part of the response when Track Relinking is applied. If true, the track is playable in the given market. Otherwise false.

    • Part of the response when Track Relinking is applied, and the requested track has been replaced with different track. The track in the linked_from object contains information about the originally requested track.

      • Included in the response when a content restriction is applied.

        • reason
          string

          The reason for the restriction. Supported values:

          • market - The content item is not available in the given market.
          • product - The content item is not available for the user's subscription type.
          • explicit - The content item is explicit and the user's account is set to not play explicit content.

          Additional reasons may be added in the future. Note: If you use this field, make sure that your application safely handles unknown values.

      • name
        string

        The name of the track.

      • popularity
        integer

        The popularity of the track. The value will be between 0 and 100, with 100 being the most popular.
        The popularity of a track is a value between 0 and 100, with 100 being the most popular. The popularity is calculated by algorithm and is based, in the most part, on the total number of plays the track has had and how recent those plays are.
        Generally speaking, songs that are being played a lot now will have a higher popularity than songs that were played a lot in the past. Duplicate tracks (e.g. the same track from a single and an album) are rated independently. Artist and album popularity is derived mathematically from track popularity. Note: the popularity value may lag actual popularity by a few days: the value is not updated in real time.

      • preview_url
        string
        Nullable

        A link to a 30 second preview (MP3 format) of the track. Can be null

        Important policy note
      • track_number
        integer

        The number of the track. If an album has several discs, the track number is the number on the specified disc.

      • type
        string

        The object type: "track".

        Allowed values: "track"
      • uri
        string

        The Spotify URI for the track.

      • is_local
        boolean

        Whether or not the track is from a local file.

    endpointhttps://api.spotify.com/v1/recommendationslimitmarketseed_artistsseed_genresseed_tracksmin_acousticnessmax_acousticnesstarget_acousticnessmin_danceabilitymax_danceabilitytarget_danceabilitymin_duration_msmax_duration_mstarget_duration_msmin_energymax_energytarget_energymin_instrumentalnessmax_instrumentalnesstarget_instrumentalnessmin_keymax_keytarget_keymin_livenessmax_livenesstarget_livenessmin_loudnessmax_loudnesstarget_loudnessmin_modemax_modetarget_modemin_popularitymax_popularitytarget_popularitymin_speechinessmax_speechinesstarget_speechinessmin_tempomax_tempotarget_tempomin_time_signaturemax_time_signaturetarget_time_signaturemin_valencemax_valencetarget_valence

    Response sample

    {  "seeds": [    {      "afterFilteringSize": 0,      "afterRelinkingSize": 0,      "href": "string",      "id": "string",      "initialPoolSize": 0,      "type": "string"    }  ],  "tracks": [    {      "album": {        "album_type": "compilation",        "total_tracks": 9,        "available_markets": ["CA", "BR", "IT"],        "external_urls": {          "spotify": "string"        },        "href": "string",        "id": "2up3OPMp9Tb4dAKM2erWXQ",        "images": [          {            "url": "https://i.scdn.co/image/ab67616d00001e02ff9ca10b55ce82ae553c8228",            "height": 300,            "width": 300          }        ],        "name": "string",        "release_date": "1981-12",        "release_date_precision": "year",        "restrictions": {          "reason": "market"        },        "type": "album",        "uri": "spotify:album:2up3OPMp9Tb4dAKM2erWXQ",        "artists": [          {            "external_urls": {              "spotify": "string"            },            "href": "string",            "id": "string",            "name": "string",            "type": "artist",            "uri": "string"          }        ]      },      "artists": [        {          "external_urls": {            "spotify": "string"          },          "href": "string",          "id": "string",          "name": "string",          "type": "artist",          "uri": "string"        }      ],      "available_markets": ["string"],      "disc_number": 0,      "duration_ms": 0,      "explicit": false,      "external_ids": {        "isrc": "string",        "ean": "string",        "upc": "string"      },      "external_urls": {        "spotify": "string"      },      "href": "string",      "id": "string",      "is_playable": false,      "linked_from": {      },      "restrictions": {        "reason": "string"      },      "name": "string",      "popularity": 0,      "preview_url": "string",      "track_number": 0,      "type": "track",      "uri": "string",      "is_local": false    }  ]}