Skip to main content

Python library to inspect and exporte metadata from MP4/M4V/M4A, MP3 and FLAC media files.

Project description

Metaspector

Metaspector is a powerful Python library and command-line tool designed for inspecting and extracting metadata from various media file formats. Whether you need to programmatically access track information, album art, or simply get a quick overview of a file's properties, Metaspector provides a clean and consistent interface.


✨ Features

  • Comprehensive Metadata Extraction: Retrieve detailed information like title, artist, album, genre, release date, track numbers, and more.

  • Audio and Video Track Details: Get specifics about video/audio codecs, channels, sample rates, bitrates, video dimensions, and more.

  • Subtitle Track Details: Get a wide variety of subtitle specific metadata like "forced only", "auxiliary content", "language translation" etc.

  • Cover Art Extraction: Easily extract embedded cover art.

  • Multi-Format Support: Currently supports:

    • 🎬 MP4/M4V/M4A (MPEG-4 incl. parsing of proprietary atoms often seen in M4V files distributed by Apple Inc.)

    • 🎵 MP3 (MPEG-1 Audio Layer III)

    • 🎧 FLAC (Free Lossless Audio Codec)

  • Flexible Output:

    • CLI: Get human-readable JSON output directly in your terminal.

    • API: Integrate seamlessly into your Python applications.

  • Section-Specific Output: Request only the metadata, audio, video, or subtitle sections for focused data retrieval.

  • Export Functionality: Export extracted metadata to JSON files or cover art to image files.

  • No Dependencies: Metaspector is a lightweight, self-contained library. It relies exclusively on built-in Python tools, requiring no external libraries to run.


🚀 Installation

You can install metaspector directly from PyPI using pip:

pip install metaspector

💡 Usage

Command-Line Interface (CLI)

The metaspector CLI provides simple and direct access to the library's main functions.

Inspect a File

To inspect a file and print all of its metadata to the terminal as JSON, use the inspect command:

metaspector inspect "/path/to/your/file.mp4"

Inspect a Specific Section

You can specify a section to get a more focused output. For example, to view only the audio track details:

metaspector inspect "/path/to/your/file.m4a" --section audio

Export Metadata

To export the full metadata of a file to a JSON file, use the export command with the meta type:

metaspector export meta "/path/to/your/file.mp3" "./output/"

This command will create a file named your_file.json in the ./output/ directory.

Export Cover Art

To extract and save the embedded cover art, use the export command with the cover type:

metaspector export cover "/path/to/your/file.flac" "./output/"

This will save the image as your_file.jpg or your_file.png in the ./output/ directory.


Python API

Metaspector's API is designed for easy integration into your Python scripts.

Basic Inspection

To get all metadata from a file, instantiate MediaInspector and call the inspect() method:

from metaspector import MediaInspector

inspector = MediaInspector("/path/to/your/file.mp4")
metadata = inspector.inspect()

print(metadata)

Get Specific Sections

You can pass the section argument to the inspect() method to retrieve only a specific part of the metadata:

from metaspector import MediaInspector

inspector = MediaInspector("/path/to/your/file.m4a")
audio_data = inspector.inspect(section="audio")

print(audio_data)

Extract Cover Art

Use the get_cover_art() method to retrieve the raw image bytes, which you can then save to a file:

from metaspector import MediaInspector

inspector = MediaInspector("/path/to/your/file.flac")
cover_art_bytes = inspector.get_cover_art()

if cover_art_bytes:
    with open("cover.jpg", "wb") as f:
        f.write(cover_art_bytes)

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

metaspector-0.1.1.tar.gz (36.2 kB view details)

Uploaded Source

Built Distribution

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

metaspector-0.1.1-py3-none-any.whl (42.8 kB view details)

Uploaded Python 3

File details

Details for the file metaspector-0.1.1.tar.gz.

File metadata

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

File hashes

Hashes for metaspector-0.1.1.tar.gz
Algorithm Hash digest
SHA256 555a506066999771dfdef5671743423e1fd31b74ab7437d80cd1140b54aa87b0
MD5 c9cc318e56e5f25e818470a575561b05
BLAKE2b-256 68bfa7a7838dac4af449db9fb5d0264eb960bf5c6214d53d9a59f3e581deb3d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for metaspector-0.1.1.tar.gz:

Publisher: publish.yaml on rsmvdl/metaspector

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

File details

Details for the file metaspector-0.1.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for metaspector-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c58263905bb274005272319d9b7bb717d7c060a448602f68f8b5e2f7ff792326
MD5 cba3208425155049f9f92a02243680a1
BLAKE2b-256 e9e98bcb67ac4d77aff7523518c42d0cbdfdd4ffa0b05efd27d51b29babc4052

See more details on using hashes here.

Provenance

The following attestation bundles were made for metaspector-0.1.1-py3-none-any.whl:

Publisher: publish.yaml on rsmvdl/metaspector

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