Skip to main content

MIDI Objects for Python

Project description

MIT License PyPi version Python version Downloads Test status Docs status REUSE status OpenSSF Best Practices

Mido is a library for working with MIDI messages and ports:

>>> import mido
>>> msg = mido.Message('note_on', note=60)
>>> msg.type
'note_on'
>>> msg.note
60
>>> msg.bytes()
[144, 60, 64]
>>> msg.copy(channel=2)
Message('note_on', channel=2, note=60, velocity=64, time=0)
port = mido.open_output('Port Name')
port.send(msg)
with mido.open_input() as inport:
    for msg in inport:
        print(msg)
mid = mido.MidiFile('song.mid')
for msg in mid.play():
    port.send(msg)

Full documentation at https://mido.readthedocs.io/

Main Features

  • convenient message objects.

  • supports RtMidi, PortMidi and Pygame. New backends are easy to write.

  • full support for all 18 messages defined by the MIDI standard.

  • standard port API allows all kinds of input and output ports to be used interchangeably. New port types can be written by subclassing and overriding a few methods.

  • includes a reusable MIDI stream parser.

  • full support for MIDI files (read, write, create and play) with complete access to every message in the file, including all common meta messages.

  • can read and write SYX files (binary and plain text).

  • implements (somewhat experimental) MIDI over TCP/IP with socket ports. This allows for example wireless MIDI between two computers.

  • includes programs for playing MIDI files, listing ports and serving and forwarding ports over a network.

Status

1.3 is the fourth stable release.

This project uses Semantic Versioning.

Requirements

Mido requires Python 3.7 or higher.

Installing

python3 -m pip install mido

Or, alternatively, if you want to use ports with the default backend:

python3 -m pip install mido[ports-rtmidi]

See docs/backends/ for other backends.

Source Code

https://github.com/mido/mido/

License

Mido is released under the terms of the MIT license.

Questions and suggestions

For questions and proposals which may not fit into issues or pull requests, we recommend to ask and discuss in the Discussions section.

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

mido-1.3.3.tar.gz (124.3 kB view details)

Uploaded Source

Built Distribution

mido-1.3.3-py3-none-any.whl (54.6 kB view details)

Uploaded Python 3

File details

Details for the file mido-1.3.3.tar.gz.

File metadata

  • Download URL: mido-1.3.3.tar.gz
  • Upload date:
  • Size: 124.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.12

File hashes

Hashes for mido-1.3.3.tar.gz
Algorithm Hash digest
SHA256 1aecb30b7f282404f17e43768cbf74a6a31bf22b3b783bdd117a1ce9d22cb74c
MD5 b4c2fe3dd8807335e75a978b30b21a70
BLAKE2b-256 2314cfda3fe61ce4c0f50a9f707ae02b46cb53211732b2cd4522bf06272848f4

See more details on using hashes here.

File details

Details for the file mido-1.3.3-py3-none-any.whl.

File metadata

  • Download URL: mido-1.3.3-py3-none-any.whl
  • Upload date:
  • Size: 54.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.12

File hashes

Hashes for mido-1.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 01033c9b10b049e4436fca2762194ca839b09a4334091dd3c34e7f4ae674fd8a
MD5 e6dfd3ee5db41f5e58d7ae8c79d0c69a
BLAKE2b-256 fd2845deb15c11859d2f10702b32e71de9328a9fa494f989626916db39a9617f

See more details on using hashes here.

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