Skip to main content

A simple Python package to interact with various music platforms APIs.

Project description

yutipy

GitHub Actions Workflow Status Documentation Status PyPI License Stars Issues

Looking for an easy-to-use API or GUI to search for music, instead of using the CLI or building your own integration? Check out yutify — it’s powered by yutipy!

A simple Python package to interact with various music platforms APIs.

Table of Contents

Features

  • Simple & Easy integration with popular music APIs.
  • Search for music by artist and song title across multiple platforms.
  • It uses RapidFuzz to compare & return the best match so that you can be sure you got what you asked for without having to worry and doing all that work by yourself.
  • Retrieve detailed music information, including album art, release dates, lyrics, ISRC, and UPC codes.
  • Authorize and access user resources easily.

Available Music Platforms

Right now, the following music platforms are available in yutipy for searching music. New platforms will be added in the future. Feel free to request any music platform you would like me to add by opening an issue on GitHub or by emailing me.

Installation

You can install the package using pip. Make sure you have Python 3.9 or higher installed.

pip install -U yutipy

Usage Example

Here's a quick example of how to use the yutipy package to search for a song on Deezer:

from yutipy.deezer import Deezer

with Deezer() as deezer:
    result = deezer.search("Artist Name", "Song Title")
    print(result)

For more usage examples, see the Usage Examples page in docs.

Command-Line Interface (CLI)

The yutipy package includes a CLI tool that allows you to search for music directly from the command line and configure API keys interactively.

Search for Music

You can use the CLI tool to search for music across multiple platforms:

yutipy-cli "Rick Astley" "Never Gonna Give You Up" --limit 3 --normalize

Options:

  • artist (required): The name of the artist.
  • song (required): The title of the song.
  • --limit: The number of results to retrieve (default: 5).
  • --normalize: Normalize non-English characters for comparison.
  • --verbose: Enable logging in the terminal.
  • --service: Specify a single service to search (e.g., deezer, spotify, itunes).

Configuration Wizard

To set up your API keys interactively, use the configuration wizard:

yutipy-config

The wizard will guide you through obtaining and setting up API keys for supported services like Spotify and KKBOX. If the required environment variables are already set, the wizard will skip those steps.

Contributing

Contributions are welcome! Please follow these steps:

  1. Fork the repository.
  2. Optionally, create an issue to discuss the changes you plan to make.
  3. Create a new branch linked to that issue.
  4. Make your changes in the new branch.
  5. Write tests if you add new functionality.
  6. Ensure all tests pass before opening a pull request.
  7. Open a pull request for review.

Thank you for your contributions!

License

This project is licensed under the MIT License. See the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

yutipy-2.3.2.tar.gz (107.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

yutipy-2.3.2-py3-none-any.whl (38.1 kB view details)

Uploaded Python 3

File details

Details for the file yutipy-2.3.2.tar.gz.

File metadata

  • Download URL: yutipy-2.3.2.tar.gz
  • Upload date:
  • Size: 107.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for yutipy-2.3.2.tar.gz
Algorithm Hash digest
SHA256 4992f113e89434193d43a2c7cc38d4ad02f2618b594a008aed021c4a06fa97cb
MD5 0616ccf56320588f01be27032182f906
BLAKE2b-256 f0fea0abd2b8cd01b39d8bfaf77e1a194df2fe319637fcb72a7f759b140b3814

See more details on using hashes here.

Provenance

The following attestation bundles were made for yutipy-2.3.2.tar.gz:

Publisher: release.yml on CheapNightbot/yutipy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file yutipy-2.3.2-py3-none-any.whl.

File metadata

  • Download URL: yutipy-2.3.2-py3-none-any.whl
  • Upload date:
  • Size: 38.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for yutipy-2.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 34c59ad9bee108a26c93e06c375b5cd2f8f0a67759e0252510b5590c7b343fcc
MD5 7b64e036dee815c5fc20fece82a13f4b
BLAKE2b-256 bb3e5b2d7d6e96be8fa8a5af2d06dde4773ee023bbc8f1ef4faad0cda7ff10c0

See more details on using hashes here.

Provenance

The following attestation bundles were made for yutipy-2.3.2-py3-none-any.whl:

Publisher: release.yml on CheapNightbot/yutipy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page