Skip to main content

cross-platform, Python audio metadata ("tagging") library based on TagLib

Project description

pytaglib

PyPI

pytaglib is a Python audio tagging library. It is cross-platform and svery simple to use yet fully featured:

pytaglib is a very thin wrapper (≈150 lines of code) around the fast and rock-solid TagLib C++ library.

News

See the Changelog.

Get it

At first, you might need to install taglib with development headers. Ubuntu, Mint and other Debian-Based distributions:

    sudo apt install libtag1-dev

On a Mac, use HomeBrew:

    brew install taglib

Then install pytaglib with pip:

    pip install pytaglib

For other operating systems and more details, see installation notes below.

Usage

>>> import taglib
>>> song = taglib.File("/path/to/my/file.mp3")
>>> song.tags
{'ARTIST': ['piman', 'jzig'], 'ALBUM': ['Quod Libet Test Data'], 'TITLE': ['Silence'], 'GENRE': ['Silence'], 'TRACKNUMBER': ['02/10'], 'DATE': ['2004']}

>>> song.length
239
>>> song.tags["ALBUM"] = ["White Album"] # always use lists, even for single values
>>> del song.tags["DATE"]
>>> song.tags["GENRE"] = ["Vocal", "Classical"]
>>> song.tags["PERFORMER:HARPSICHORD"] = ["Ton Koopman"] 
>>> song.save()

For detailed API documentation, use the docstrings of the taglib.File class or view the source code directly.

pyprinttags

This package also installs the pyprinttags script. It takes one or more files as command-line parameters and will display all known metadata of that files on the terminal. If unsupported tags (a.k.a. non-textual information) are found, they can optionally be removed from the file.

Installation Notes

  • Ensure that pip is installed and points to the correct Python version
    • on Windows, be sure to check install pip in the Python installer
    • on Debian/Ubuntu/Mint, install python3-pip
    • you might need to type, e.g., pip-3 to install pytaglib for Python 3 if your system's default is Python 2.x.
  • For Windows users, there are some precompiled binary packages (wheels). See the PyPI page for a list of supported Python versions.
  • If no binary packages exists, you need to have both Python and taglib installed with development headers (packages python3-dev (or python-dev) and libtag1-dev for debian / ubuntu and derivates, python-devel and taglib-devel for fedora and friends, brew install taglib on OS X).

Linux: Distribution-Specific Packages

  • Debian- and Ubuntu-based linux flavors have binary packages for the Python 3 version, called python3-taglib. Unfortunatelly, they are heavily outdated, so you should instally the recent version via pip whenever possible.
  • For Arch users, there is a package in the user repository (AUR).

Manual Compilation: General

You can download or checkout the sources and compile manually:

    python setup.py build
    python setup.py test  # optional, run unit tests
    sudo python setup.py install

Note: The taglib Python extension is built from taglib.cpp which in turn is auto-generated by Cython from taglib.pyx. To regenerate the taglib.cpp after making changes to taglib.pyx, set the environment variable PYTAGLIB_CYTHONIZE to 1 before calling setup.py or pip.

Compilation: Windows

Install MS Visual Studio Build Tools (or the complete IE) and include the correct compiler version as detailed here. Also enable cmake in the Visual Studio Installer.

Then:

  • open the VS native tools command prompt
  • navigate to the pytaglib repository
  • run python build_taglib_windows.py which will download and build the latest official TagLib release
  • run python setup.py install

Contact

For bug reports or feature requests, please use the issue tracker on GitHub. For anything else, contact me by email.

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

pytaglib-1.5.0.tar.gz (467.7 kB view hashes)

Uploaded Source

Built Distributions

pytaglib-1.5.0-py3.10-win-amd64.egg (218.0 kB view hashes)

Uploaded Source

pytaglib-1.5.0-py3.10-linux-x86_64.egg (190.9 kB view hashes)

Uploaded Source

pytaglib-1.5.0-py3.9-win-amd64.egg (217.9 kB view hashes)

Uploaded Source

pytaglib-1.5.0-py3.9-linux-x86_64.egg (186.5 kB view hashes)

Uploaded Source

pytaglib-1.5.0-py3.8-win-amd64.egg (218.1 kB view hashes)

Uploaded Source

pytaglib-1.5.0-py3.8-linux-x86_64.egg (195.3 kB view hashes)

Uploaded Source

pytaglib-1.5.0-cp310-cp310-win_amd64.whl (228.6 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

pytaglib-1.5.0-cp39-cp39-win_amd64.whl (228.6 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

pytaglib-1.5.0-cp38-cp38-win_amd64.whl (228.7 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

Supported by

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