# easy-playlist
**A library to easily manage yours playlists in python**
## Getting started
1. [**Installation**](#installation)
2. [**Usages**](#usages)
3. [**Code example**](#code-example)
4. [**Documentation**](https://github.com/ThePhoenix78/easy-playlist/blob/main/DOCUMENTATION.md)
## Installation
**This library will work with python 3.6+**
PyPi : `pip install easy-playlist`
GitHub : [Github](https://github.com/ThePhoenix78/easy-playlist)
## Usages
This library will work with any files, it use ffmpeg to get the lenght
It's was desinged to work with bots in general
## Code example
### Simple tasks
```py
from easy_playlist import Playlists
pls = Playlists()
pl = pls.add_playlist("test")
# pl = pls.get_playlist("test")
# add music to your playlist
pl.add_music("path_to_music.mp3")
pl.add_music(["path_to_music.mp3", "path_to_other_music.mp3"])
# trigger the timer
# this will take the first song of the playlist
pl.play()
# pause the timer
pl.pause()
# resume the timer
pl.resume()
# stop the current music and trigger the timer for the next one
pl.next()
# stop the current music and trigger the timer for the previous one
pl.previous()
# stop the timer and the music
pl.stop()
# IMPORTANT
# when you don't need to use the playlist anymore do this
# this library use a thread to calculate the time
pl.exit()
```
### To make it work with a bot
```py
from easy_playlist import Playlists
# any bot library
bot = Bot()
pls = Playlists()
pl = pls.add_playlist("test")
# pl = pls.get_playlist("test")
# code example
@bot.command()
def add_music(music):
pl.add_music(music)
@bot.command()
def pause():
pl.pause()
bot.pause_music()
@bot.command()
def resume():
pl.resume()
bot.resume_music()
@bot.command()
def play(music):
pl.play(music)
bot.play_music(music)
@pl.on_music_over()
def music_over(data):
print(f"{data.playlist.name} {data.music.name} is over, playing next now")
pl.next()
bot.play_music(pl.get_current().file)
```
### An other code to explain
```py
pl = Playlists()
pl1 = pl.add_playlist(name="test1", playlist=["music/bip1.mp3", "music/bip2.mp3"])
pl2 = pl.add_playlist(name="test2", playlist=["music/bip1.mp3", "music/bip2.mp3"])
pl.add_music("test1", "music/bip3.mp3")
# pl1 = pl.get_playlist("test1")
# pl2 = pl.get_playlist("test2")
pl1.play()
pl2.play()
print("starting...")
@pl.on_music_over()
def music_over(data):
print(f"[{data.playlist.name}] {data.music.name} is over, next song now!")
if data.playlist.is_over():
print(f"Playlist {data.playlist.name} is over")
data.playlist.clear()
return
data.playlist.next()
```
Raw data
{
"_id": null,
"home_page": "https://github.com/ThePhoenix78/easy-playlist",
"name": "easy-playlist",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "playlist, music, timer",
"author": "ThePhoenix78",
"author_email": "thephoenix788@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/04/f7/98e14d560e74f90a9c3247480dbd9e55e2844ae2557b4ea969810b5fc8d1/easy_playlist-1.8.2.tar.gz",
"platform": null,
"description": "# easy-playlist\r\n\r\n**A library to easily manage yours playlists in python**\r\n\r\n## Getting started\r\n\r\n1. [**Installation**](#installation)\r\n2. [**Usages**](#usages)\r\n3. [**Code example**](#code-example)\r\n4. [**Documentation**](https://github.com/ThePhoenix78/easy-playlist/blob/main/DOCUMENTATION.md)\r\n\r\n\r\n## Installation\r\n\r\n**This library will work with python 3.6+**\r\n\r\nPyPi : `pip install easy-playlist`\r\n\r\nGitHub : [Github](https://github.com/ThePhoenix78/easy-playlist)\r\n\r\n\r\n## Usages\r\n\r\nThis library will work with any files, it use ffmpeg to get the lenght\r\nIt's was desinged to work with bots in general\r\n\r\n\r\n## Code example\r\n\r\n### Simple tasks\r\n\r\n```py\r\nfrom easy_playlist import Playlists\r\n\r\npls = Playlists()\r\npl = pls.add_playlist(\"test\")\r\n# pl = pls.get_playlist(\"test\")\r\n\r\n# add music to your playlist\r\npl.add_music(\"path_to_music.mp3\")\r\npl.add_music([\"path_to_music.mp3\", \"path_to_other_music.mp3\"])\r\n\r\n# trigger the timer\r\n# this will take the first song of the playlist\r\npl.play()\r\n\r\n# pause the timer\r\npl.pause()\r\n\r\n# resume the timer\r\npl.resume()\r\n\r\n# stop the current music and trigger the timer for the next one\r\npl.next()\r\n\r\n# stop the current music and trigger the timer for the previous one\r\npl.previous()\r\n\r\n# stop the timer and the music\r\npl.stop()\r\n\r\n# IMPORTANT\r\n# when you don't need to use the playlist anymore do this\r\n# this library use a thread to calculate the time\r\npl.exit()\r\n```\r\n\r\n### To make it work with a bot\r\n\r\n```py\r\nfrom easy_playlist import Playlists\r\n\r\n# any bot library\r\nbot = Bot()\r\npls = Playlists()\r\npl = pls.add_playlist(\"test\")\r\n\r\n# pl = pls.get_playlist(\"test\")\r\n\r\n\r\n# code example\r\n\r\n\r\n@bot.command()\r\ndef add_music(music):\r\n\tpl.add_music(music)\r\n\r\n\r\n@bot.command()\r\ndef pause():\r\n\tpl.pause()\r\n\tbot.pause_music()\r\n\r\n\r\n@bot.command()\r\ndef resume():\r\n\tpl.resume()\r\n\tbot.resume_music()\r\n\r\n\r\n@bot.command()\r\ndef play(music):\r\n\tpl.play(music)\r\n\tbot.play_music(music)\r\n\r\n\r\n@pl.on_music_over()\r\ndef music_over(data):\r\n\tprint(f\"{data.playlist.name} {data.music.name} is over, playing next now\")\r\n\tpl.next()\r\n\tbot.play_music(pl.get_current().file)\r\n\r\n```\r\n\r\n### An other code to explain\r\n\r\n```py\r\npl = Playlists()\r\npl1 = pl.add_playlist(name=\"test1\", playlist=[\"music/bip1.mp3\", \"music/bip2.mp3\"])\r\npl2 = pl.add_playlist(name=\"test2\", playlist=[\"music/bip1.mp3\", \"music/bip2.mp3\"])\r\npl.add_music(\"test1\", \"music/bip3.mp3\")\r\n\r\n# pl1 = pl.get_playlist(\"test1\")\r\n# pl2 = pl.get_playlist(\"test2\")\r\n\r\npl1.play()\r\npl2.play()\r\n\r\nprint(\"starting...\")\r\n\r\n\r\n@pl.on_music_over()\r\ndef music_over(data):\r\n print(f\"[{data.playlist.name}] {data.music.name} is over, next song now!\")\r\n\r\n if data.playlist.is_over():\r\n print(f\"Playlist {data.playlist.name} is over\")\r\n data.playlist.clear()\r\n return\r\n\r\n data.playlist.next()\r\n```\r\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A library to easily manage your playlists in python",
"version": "1.8.2",
"project_urls": {
"Download": "https://github.com/ThePhoenix78/easy-playlist/tarball/master",
"Homepage": "https://github.com/ThePhoenix78/easy-playlist"
},
"split_keywords": [
"playlist",
" music",
" timer"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ea55faa9c3882d205765ee732d055967c6c5c74f297aedc7803d8674afcd1cf7",
"md5": "41e832976a2deb1956ca1a35ca09f317",
"sha256": "1922cc9d901be73994f0b76cebb7a9eafe5215236437c8c23bf6c16bb806b323"
},
"downloads": -1,
"filename": "easy_playlist-1.8.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "41e832976a2deb1956ca1a35ca09f317",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 6201,
"upload_time": "2025-01-18T22:20:12",
"upload_time_iso_8601": "2025-01-18T22:20:12.047496Z",
"url": "https://files.pythonhosted.org/packages/ea/55/faa9c3882d205765ee732d055967c6c5c74f297aedc7803d8674afcd1cf7/easy_playlist-1.8.2-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "04f798e14d560e74f90a9c3247480dbd9e55e2844ae2557b4ea969810b5fc8d1",
"md5": "f97681de76716ba587fb9a70fc818bd9",
"sha256": "a64bbfbb8119b02321fabb1d9820ab3b4a51af7907c82cb7c079ef2ce69c8c8c"
},
"downloads": -1,
"filename": "easy_playlist-1.8.2.tar.gz",
"has_sig": false,
"md5_digest": "f97681de76716ba587fb9a70fc818bd9",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 6266,
"upload_time": "2025-01-18T22:20:14",
"upload_time_iso_8601": "2025-01-18T22:20:14.331349Z",
"url": "https://files.pythonhosted.org/packages/04/f7/98e14d560e74f90a9c3247480dbd9e55e2844ae2557b4ea969810b5fc8d1/easy_playlist-1.8.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-18 22:20:14",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "ThePhoenix78",
"github_project": "easy-playlist",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "easy-playlist"
}