A module to parse, analyze and validate MPEG-DASH MPD
Project description
mpd-inspector
Python module to parse MPEG-DASH Media Presentation Documents (aka. MPD) from files or URLs, and inspect them. With support for SCTE35 events (binary and/or XML).
Overview
The library provides two main components: the MPDParser and the MPDInspector. The MPDParser is responsible for parsing the MPD XML content (from a file, URL, or string) into a structured Python object model, converting attributes into native Python types where appropriate. It is meant to be a one-to-one mapping of the content of the MPD file to the object model.
The MPDInspector takes a parsed MPD object and provides a higher-level interface for analysis and interpretation. It calculates implicit and derived values (such as segment URLs based on templates, or accurate start/end times for periods), determines provenance for values, and offers helper methods for common tasks like checking if a presentation is live or on-demand.
Origin
This package was initially built as a fork from the excellent mpd-parser. The main reasons for forking it are:
- I needed to change the behaviour to be closer to the MPEG-DASH spec, in particular DASH-IF IOP rules.
- I wanted to parse all MPD attributes into native Python types (including for datetimes and durations)
- I wanted to be able to expose unparsed elements
- I wanted to add a layer of inspection/analysis to make it possible to calculate implicit/derived values (eg. start and duration of periods in multi-period MPD) - in particular again for validation against the DASH-IF Interoperability guidance
- I wanted to add support for SCTE35 Events (both as binary and XML)
Installation
$ python -m pip install mpd-inspector
Usage
Parsing a MPD manifest
from mpd_inspector import MPDParser, MPDInspector
from string
with open("path/to/file.mpd", mode="r") as manifest_file:
mpd_string = manifest_file.read()
parsed_mpd = MPDParser.from_string(mpd_string)
from file
input_file = "path/to/file.mpd"
mpd = MPDParser.from_file(input_file)
from url
input_url = "https://my-server.com/path/to/stream.mpd"
mpd = MPDParser.from_url(input_url)
Inspecting the MPD manifest
Once you have a parsed MPD object (mpd), you can create an inspector:
inspector = MPDInspector(mpd)
# Check basic MPD properties
print(f"MPD ID: {inspector.id}")
print(f"Type: {'Live' if inspector.is_live() else 'VOD'}")
if inspector.is_live():
print(f"Availability Start Time: {inspector.availability_start_time}")
else:
print(f"Media Presentation Duration: {inspector.media_presentation_duration}")
# Iterate through Periods
for period in inspector.periods:
print(f" Period {period.sequence} Start: {period.start_time}, Duration: {period.duration}")
print(f" Duration Provenance: {period.get_value_provenance('duration')}") # EXPLICIT, DERIVED, DEFAULT
# Iterate through Adaptation Sets (Video, Audio, etc.)
for adap_set in period.adaptation_sets:
print(f" Adaptation Set MIME Type: {adap_set.mime_type}")
# Iterate through Representations (different bitrates/resolutions)
for representation in adap_set.representations:
print(f" Representation ID: {representation.id}, Bandwidth: {representation.bandwidth}")
# Get segment information
segment_info = representation.segment_information
print(f" Segment Addressing Mode: {segment_info.addressing_mode}") # e.g., SIMPLE, EXPLICIT
# Get segment URLs (using a generator)
# Note: For large manifests, avoid converting the generator to a list immediately
segment_generator = segment_info.segments
try:
first_segment = next(segment_generator)
print(f" First Segment URL(s): {first_segment.urls}")
print(f" First Segment Start Time: {first_segment.start_time}")
print(f" First Segment Duration: {first_segment.duration}")
except StopIteration:
print(" No segments found for this representation.")
For more examples, I would suggest looking at the tests.
Example manifests
There are a variety of example manifests in the manifests directory, coming from a variety of sources.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mpd_inspector-1.2.1.tar.gz.
File metadata
- Download URL: mpd_inspector-1.2.1.tar.gz
- Upload date:
- Size: 21.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.13.11 Darwin/24.6.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b05adea94b271ef0809ddfeb027a6f302b9eb42a5dd6a93d011795c764db5017
|
|
| MD5 |
6fad5d53d01094521151e7eb8741d2fd
|
|
| BLAKE2b-256 |
87c7ac471e4271bf0147af19023f33087a689d8d0db3ec58950cff9fca12ed17
|
File details
Details for the file mpd_inspector-1.2.1-py3-none-any.whl.
File metadata
- Download URL: mpd_inspector-1.2.1-py3-none-any.whl
- Upload date:
- Size: 25.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.13.11 Darwin/24.6.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d68a137eb751a71737b80b7ceb5acd2f8e01d06334d27d774d4b499e8869915d
|
|
| MD5 |
ec3869113c5d2e4f1fa52bd22b7a0944
|
|
| BLAKE2b-256 |
945685173dc6c912aa2edb7941f22235adf169e0ecd44490c87c3c9c433d7cbf
|