An utility to render note block songs to a variety of audio formats
Project description
nbswave
A Python package to render note block songs to a variety of audio formats.
Overview
nbswave is a Python package aimed at rendering note block songs from Open Note Block Studio to audio tracks. Supports many common audio formats, both for loading custom sounds as well as exporting tracks.
Setup
The package can be installed with pip
.
$ pip install nbswave
In order to use the package, FFmpeg must be available:
- Download precompiled binaries for
ffmpeg
andffprobe
here. - Add the destination folder to your
PATH
, or, alternatively, place both executables in the root folder of the project.
Usage
from nbswave import *
render_audio("song.nbs", "output.mp3")
The output format will be detected automatically based on the file extension. You can still specify it explicitly if you'd like:
from nbswave import *
render_audio("song.nbs", "output", format='wav')
Compatibility with audio formats depends on your FFmpeg configuration.
Custom instruments
In order to render songs with custom instruments, you have a few options:
-
Copy the sounds manually to the
sounds
folder -
Pass the path to a folder (or ZIP file) containing custom sounds:
from pathlib import Path
nbs_sounds_folder = Path.home() / "Minecraft Note Block Studio" / "Data" / "Sounds"
render_audio("song.nbs", "output.mp3", custom_sound_path=nbs_sounds_folder)
If any sound file used in the song is not found in that location, a MissingInstrumentException
will be raised. This behavior can be suppressed with the following argument:
render_audio("song.nbs", "output.mp3", ignore_missing_instruments=True)
Advanced usage
For more advanced use cases where you might need more control over the export process, it's possible to use the SongRenderer
class. This will allow you to load custom instruments from multiple sources, as well as query which instruments are still missing:
from nbswave import *
renderer = SongRenderer("song.nbs")
renderer.load_instruments(nbs_sounds_folder)
renderer.load_instruments("some_more_instruments.zip")
renderer.missing_instruments()
renderer.mix_song()
Contributing
Contributions are welcome! Make sure to open an issue discussing the problem or feature suggestion before creating a pull request.
This project uses poetry for managing dependencies. Make sure to install it, and run:
$ poetry install
This project follows the black code style. Import statements are sorted with isort.
$ poetry run isort nbswave
$ poetry run black nbswave
$ poetry run black --check nbswave
License - MIT
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
Built Distribution
File details
Details for the file nbswave-0.2.1.tar.gz
.
File metadata
- Download URL: nbswave-0.2.1.tar.gz
- Upload date:
- Size: 8.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.9.5 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 65b0290889d4e9e7085ad2fce57e1e94d0e6c8adb7a3717ba275b973aaae63af |
|
MD5 | 3394b149de8d1fcef6970c85051d0807 |
|
BLAKE2b-256 | cce307aa51d7b217ccdfcd989e9b601cdf0ffcafd982f0c55c0f0429ebbd86b4 |
File details
Details for the file nbswave-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: nbswave-0.2.1-py3-none-any.whl
- Upload date:
- Size: 10.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.9.5 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1ad8ab623eedf82a9ef1bbd033e60738c6508c696255cf9233e376a54849ca63 |
|
MD5 | 06e78248e3e8450793603367e7b505c5 |
|
BLAKE2b-256 | ce0490bb3e1d3be472e67dc92ce22802fa3c2984a304ba26bd56be08b8cb0325 |