-
-
Notifications
You must be signed in to change notification settings - Fork 73
Generator Codes
It's possible to set a playlist's contents to be determined by a generator, that being, a set of codes you can use that represent functions that will be applied to make a playlist. This is analogous to smart playlist features of other music players.
-
You can create/edit a playlist's generator code by using the shortcut Ctrl + E.
-
If you create a new playlist by selecting
Generate...
or from the global search, the new playlist will have an applicable code already applied. -
A generator can triggered either manually by right clicking a playlist tab and clicking
Regenerate
or be triggered automatically by including generator codeauto
.
There are 4 types of codes: Selectors, Searchers, Filters and Sorters. Only one search code is required at minimum.
The order is important. Typically you:
- Select any particular playlists to restrict search scope to (optional)
- Perform a search or simply add all tracks using the
a
code - Add any filters or sorters (optional)
For example, if you wanted a playlist of all your loved tracks you could use: a l
. If you wanted all loved tracks from only a specific playlist, you could use: s"MyPlaylist" a l
If you wanted all loved tracks from a specific artist, you could use: a"Artistname" l
Function | Code example | Notes |
---|---|---|
Add playlist to selection | s"Name of Playlist" | If no selection is made, all playlists will be selected |
Clear selection | clr | Selects all playlists as per above rule |
Select current playlist | self | This is a special code that makes the selection the playlist itself. Useful when combined with auto and any sorters to re-sort tracks on import. Using any filter codes with this will be destructive. |
Note: Entries in Bold are additional codes not shown in the in-app legend.
Function | Code example | Notes |
---|---|---|
Search artist | a"Artist Name" | This is a search term, so it can be fuzzy like: a"arti"
|
Search genre | g"Rock" | You can combine multiple of these like g"k-pop" g"j-pop"
|
Find in all | f"artist" | This produces the same results as the find box. Includes searching the filename (can be a partial stem like p"ingles/cold" , a folder name, or a full folder path) and comment, but not lyrics or genre. |
Find string in all | fs"artist" | Same as above but for matching an exact sequence (Useful for searches where spaces are important) |
Add by file type | ext"flac" | You could also do f".flac" which will probably give you what you want since that includes searching the filename, but you would need this function to include; say; your Airsonic collection by doing ext"sub"
|
Add all tracks from selection | a | You will need this if you didn't perform any of the above searches |
Function | Code example | Notes |
---|---|---|
Max number of tracks | n123 | In this case, limits playlist to 123 tracks |
Year greater than | y>2015 | This can also be inclusive by using y>=2016
|
Year less than | y<2016 | This can also be inclusive by using y<=2016
|
Year equals | y=2016 | This would be the equivient of doing y>2015 y<2017
|
Playcount greater than | pc>5 | |
Playcount less then | pc<10 | For example, combining this and the above like pc>5 pc<10 will filter the playlist to only include tracks with playcounts of 6 to 9 |
Playtime greater than | pt>5 | |
Playtime less then | pt<10 | |
Duration less than | d<30 | In seconds. In this case, playlist will only include tracks less than 30 seconds |
Duration greater than | d>300 | In seconds. In this case, playlist will only include tracks greater then 5 minutes |
Rating greater than | rat>2 | In this case, includes tracks with more than 2 stars |
Rating less than | rat<4.5 | In this case, includes tracks with less than 4.5 stars |
Rating equals | rat=5 | In this case, includes tracks with exactly 5 stars |
Loved tracks | l | |
Has lyrics | ly | |
Has cue sheet | cue | Only keeps tracks that are part of a larger file |
Today's day of the year | today | Includes release dates that match today's month and day. Tracks will need to have full date in date field |
Comment match | com"bandcamp" | The f"" code already includes searching the comment, but you can use this code to only search the comment. (Also this must be an exact match of a string segment and isn't fuzzy like f"text" ) |
Find and keep | ff"text" | Same as f"text" but only for tracks already included, discarding non-matches. |
Find and exclude | fx"text" | Same as ff"text" but removes matching tracks. |
Exclude playlist | px"playlistname" | Exclude tracks that appear in a particular playlist. (Added in v7.2.0) |
Function | Code example | Notes |
---|---|---|
Shuffle tracks | st | |
Shuffle albums | sf | |
Year Oldest to Latest | y> | |
Year Latest to Oldest | y< | |
Playtime highest | pt> | |
Playtime lowest | pt< | |
Duration longest | d> | |
Duration shortest | d< | |
Most played albums | pa> | |
Least played albums | pa< | |
Reversed tracks | rv | |
Reversed albums | rva | |
Highest track ratings | rat> | If you would like to exclude tracks that don't have a rating, use rat rat>
|
Lowest track ratings | rat< | If you would like to exclude tracks that don't have a rating, use rat rat<
|
Highest album ratings | rata> | |
Recently modified files | m> | This is read from the modification date of the file at the time it was imported. Won't work with network tracks. |
Oldest modified files | m< | |
Track numbers per album | tn | |
Year per artist | ypa | Use this if you want discographies in order for each artist. (Artists albums must already be grouped together in the playlist). |
Sort tracks by filepath | path | This may not be the same order as was originally imported |
Column sort | "bitrate"> | Sort by any column. Name must be the exact title of a column as shown in the columns view. Can also use < to sort in reverse |
Function | Code | Notes |
---|---|---|
Automatically update | auto |
Function | Code String |
---|---|
Search for Coldplay from playlist Default and show tracks that have a playcount of less than 2 | s"Default" a"Coldplay" pc<2 |
Shuffle albums from every playlist | a sf |
Take 10 random tracks from the playlist Default | s"Default" a st n10 |
Show loved tracks of artists Coldplay and Red Hot Chili Peppers in order of playcount from playlists Default and Downloads. Tip: You can shorten the names and it will (probably) still return what you want. |
s"De" s"Do" a"Col" a"Red H" pt> l |
Note: If you rename a targeted playlist, you will need to update any strings manually.
Note: If multiple playlists have the same name, just the first one will be selected.
Important: Its best to keep your source playlists as the top/leftmost playlists in the panel/top-tab-bar, appearing before any generator playlists. If you have a main library playlist, keep it as the first playlist.