music-snapshot


Namemusic-snapshot JSON
Version 0.1.0 PyPI version JSON
download
home_pageNone
SummarySave a snapshot of your day as a Spotify playlist.
upload_time2024-11-16 01:28:22
maintainerNone
docs_urlNone
authorNone
requires_python>=3.10
licenseNone
keywords spotify playlist cli
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # music_snapshot
[![Package Version](https://img.shields.io/pypi/v/music_snapshot)][pypi music_snapshot]
[![Supported Python Versions](https://img.shields.io/pypi/pyversions/music_snapshot)][pypi music_snapshot]
[![Codecov](https://img.shields.io/codecov/c/github/pawelad/music_snapshot)][codecov music_snapshot]
[![License](https://img.shields.io/pypi/l/music_snapshot)][license]
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)][black]
[![py.typed](https://img.shields.io/badge/py-typed-FFD43B)][pep561]

Save a snapshot of your day as a Spotify playlist.

[![Demo](./demo.gif)][asciicast music_snapshot]

## Installation
Since `music_snapshot` is a command line tool, the recommended installation method
is via [pipx]:

```console
$ pipx install music_snapshot
```

Of course, you can just install it directly from [PyPI] (ideally, inside a
[virtualenv]):

```console
$ python -m pip install music_snapshot
```

## Quick start

### Authentication
To use `music_snapshot` you need to authorize it with both Spotify and Last.fm.

To get Spotify client ID and secret, create an OAuth client in
[Spotify developer dashboard] (with the "Redirect URI" set to 
`http://localhost:6600/music_snapshot`).

To get Last.fm API keys, you need create a [new Last.fm API account].

After obtaining all of the above, you need to run `music_snapshot authorize`
which will save your config data in `~/.music_snapshot` and allow you to create
new music snapshots with `music_snapshot create` subcommand.

### Usage
The default subcommand is `create`, which helps you create a new music snapshot
(Spotify playlist).

You can see all available subcommands and options by running `music_snapshot --help`:

```console
$ music_snapshot --help          
                                                                                        
 Usage: music_snapshot [OPTIONS] COMMAND [ARGS]...                                      
                                                                                        
 Save a snapshot of your day as a Spotify playlist.                                     
 Have you ever just let Spotify algorithm do its thing, keep going long after your      
 queue has finished and ended in a place you'd like to go back to? I'm here to help you 
 do just that.                                                                          
                                                                                        
 A 'music snapshot' is a Spotify playlist that encapsulates a part of your music        
 playing history.                                                                       
                                                                                        
 Unfortunately, because of Spotify API limitations (no accessible history of played     
 songs) the song history comes from your Last.fm account.                               
                                                                                        
 To use the app, you need to first create a new Spotify OAuth app in its developer      
 dashboard and get Last.fm API keys by creating a new API account. You can then use     
 those values in the authorize subcommand, which will also save the underlying data on  
 your disk.                                                                             
                                                                                        
╭─ Options ────────────────────────────────────────────────────────────────────────────╮
│ --version      Show the version and exit.                                            │
│ --help         Show this message and exit.                                           │
╰──────────────────────────────────────────────────────────────────────────────────────╯
╭─ Commands ───────────────────────────────────────────────────────────────────────────╮
│ authorize  Authorize music_snapshot with Spotify and Last.fm.                        │
│ create     Create a new music snapshot (Spotify playlist).                           │
╰──────────────────────────────────────────────────────────────────────────────────────╯
```

## Authors
Developed and maintained by [Paweł Adamczak][pawelad].

Source code is available at [GitHub][github music_snapshot].

If you'd like to contribute, please take a look at the
[contributing guide].

Released under [Mozilla Public License 2.0][license].


[asciicast music_snapshot]: https://asciinema.org/a/689879
[black]: https://github.com/psf/black
[codecov music_snapshot]: https://app.codecov.io/github/pawelad/music_snapshot
[contributing guide]: ./CONTRIBUTING.md
[github music_snapshot]: https://github.com/pawelad/music_snapshot
[license]: ./LICENSE
[new last.fm api account]: https://www.last.fm/api/account/create
[pawelad]: https://pawelad.me/
[pep561]: https://peps.python.org/pep-0561/
[pipx]: https://github.com/pypa/pipx
[pypi music_snapshot]: https://pypi.org/project/music_snapshot/
[spotify developer dashboard]: https://developer.spotify.com/dashboard
[virtualenv]: https://packaging.python.org/en/latest/guides/installing-using-pip-and-virtual-environments/


            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "music-snapshot",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.10",
    "maintainer_email": null,
    "keywords": "spotify, playlist, cli",
    "author": null,
    "author_email": "Pawe\u0142 Adamczak <pawel.ad@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/26/c9/4743aa9068bc54522e2d2dab926ec111532a01e38fadb8dce37ea08cbdda/music_snapshot-0.1.0.tar.gz",
    "platform": null,
    "description": "# music_snapshot\n[![Package Version](https://img.shields.io/pypi/v/music_snapshot)][pypi music_snapshot]\n[![Supported Python Versions](https://img.shields.io/pypi/pyversions/music_snapshot)][pypi music_snapshot]\n[![Codecov](https://img.shields.io/codecov/c/github/pawelad/music_snapshot)][codecov music_snapshot]\n[![License](https://img.shields.io/pypi/l/music_snapshot)][license]\n[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)][black]\n[![py.typed](https://img.shields.io/badge/py-typed-FFD43B)][pep561]\n\nSave a snapshot of your day as a Spotify playlist.\n\n[![Demo](./demo.gif)][asciicast music_snapshot]\n\n## Installation\nSince `music_snapshot` is a command line tool, the recommended installation method\nis via [pipx]:\n\n```console\n$ pipx install music_snapshot\n```\n\nOf course, you can just install it directly from [PyPI] (ideally, inside a\n[virtualenv]):\n\n```console\n$ python -m pip install music_snapshot\n```\n\n## Quick start\n\n### Authentication\nTo use `music_snapshot` you need to authorize it with both Spotify and Last.fm.\n\nTo get Spotify client ID and secret, create an OAuth client in\n[Spotify developer dashboard] (with the \"Redirect URI\" set to \n`http://localhost:6600/music_snapshot`).\n\nTo get Last.fm API keys, you need create a [new Last.fm API account].\n\nAfter obtaining all of the above, you need to run `music_snapshot authorize`\nwhich will save your config data in `~/.music_snapshot` and allow you to create\nnew music snapshots with `music_snapshot create` subcommand.\n\n### Usage\nThe default subcommand is `create`, which helps you create a new music snapshot\n(Spotify playlist).\n\nYou can see all available subcommands and options by running `music_snapshot --help`:\n\n```console\n$ music_snapshot --help          \n                                                                                        \n Usage: music_snapshot [OPTIONS] COMMAND [ARGS]...                                      \n                                                                                        \n Save a snapshot of your day as a Spotify playlist.                                     \n Have you ever just let Spotify algorithm do its thing, keep going long after your      \n queue has finished and ended in a place you'd like to go back to? I'm here to help you \n do just that.                                                                          \n                                                                                        \n A 'music snapshot' is a Spotify playlist that encapsulates a part of your music        \n playing history.                                                                       \n                                                                                        \n Unfortunately, because of Spotify API limitations (no accessible history of played     \n songs) the song history comes from your Last.fm account.                               \n                                                                                        \n To use the app, you need to first create a new Spotify OAuth app in its developer      \n dashboard and get Last.fm API keys by creating a new API account. You can then use     \n those values in the authorize subcommand, which will also save the underlying data on  \n your disk.                                                                             \n                                                                                        \n\u256d\u2500 Options \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256e\n\u2502 --version      Show the version and exit.                                            \u2502\n\u2502 --help         Show this message and exit.                                           \u2502\n\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256f\n\u256d\u2500 Commands \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256e\n\u2502 authorize  Authorize music_snapshot with Spotify and Last.fm.                        \u2502\n\u2502 create     Create a new music snapshot (Spotify playlist).                           \u2502\n\u2570\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u256f\n```\n\n## Authors\nDeveloped and maintained by [Pawe\u0142 Adamczak][pawelad].\n\nSource code is available at [GitHub][github music_snapshot].\n\nIf you'd like to contribute, please take a look at the\n[contributing guide].\n\nReleased under [Mozilla Public License 2.0][license].\n\n\n[asciicast music_snapshot]: https://asciinema.org/a/689879\n[black]: https://github.com/psf/black\n[codecov music_snapshot]: https://app.codecov.io/github/pawelad/music_snapshot\n[contributing guide]: ./CONTRIBUTING.md\n[github music_snapshot]: https://github.com/pawelad/music_snapshot\n[license]: ./LICENSE\n[new last.fm api account]: https://www.last.fm/api/account/create\n[pawelad]: https://pawelad.me/\n[pep561]: https://peps.python.org/pep-0561/\n[pipx]: https://github.com/pypa/pipx\n[pypi music_snapshot]: https://pypi.org/project/music_snapshot/\n[spotify developer dashboard]: https://developer.spotify.com/dashboard\n[virtualenv]: https://packaging.python.org/en/latest/guides/installing-using-pip-and-virtual-environments/\n\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Save a snapshot of your day as a Spotify playlist.",
    "version": "0.1.0",
    "project_urls": {
        "GitHub": "https://github.com/pawelad/music_snapshot",
        "Homepage": "https://music_snapshot.pawelad.dev/",
        "Issues": "https://github.com/pawelad/music_snapshot/issues"
    },
    "split_keywords": [
        "spotify",
        " playlist",
        " cli"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e346d6d7b1c036a9f2720275ebb2d4140df97f308188920956f7425f168a5d26",
                "md5": "e7dc7ff329aa1eb5b4c45576117c5d33",
                "sha256": "05cf297965c70dc9fdb37bb97c4d01f1c19fd21f5978ad7626a14f64c5711dbb"
            },
            "downloads": -1,
            "filename": "music_snapshot-0.1.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "e7dc7ff329aa1eb5b4c45576117c5d33",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.10",
            "size": 18094,
            "upload_time": "2024-11-16T01:28:21",
            "upload_time_iso_8601": "2024-11-16T01:28:21.048897Z",
            "url": "https://files.pythonhosted.org/packages/e3/46/d6d7b1c036a9f2720275ebb2d4140df97f308188920956f7425f168a5d26/music_snapshot-0.1.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "26c94743aa9068bc54522e2d2dab926ec111532a01e38fadb8dce37ea08cbdda",
                "md5": "0183a81595bbe17abf476110ec353727",
                "sha256": "1d2afe70a887cd77ee93e0e51264c3820c600d90b8bbab3f4ec06c7649956125"
            },
            "downloads": -1,
            "filename": "music_snapshot-0.1.0.tar.gz",
            "has_sig": false,
            "md5_digest": "0183a81595bbe17abf476110ec353727",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.10",
            "size": 16877,
            "upload_time": "2024-11-16T01:28:22",
            "upload_time_iso_8601": "2024-11-16T01:28:22.353122Z",
            "url": "https://files.pythonhosted.org/packages/26/c9/4743aa9068bc54522e2d2dab926ec111532a01e38fadb8dce37ea08cbdda/music_snapshot-0.1.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-16 01:28:22",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "pawelad",
    "github_project": "music_snapshot",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "music-snapshot"
}
        
Elapsed time: 0.34581s