Skip to main content

Parser for Ultrastar text files.

Project description

UltrastarParser

Contains methods to read or edit ultrastar files or directories.

Installation

Use the package manager of your choice: pypi.

Usage tips

  • Make a backup of the text files. The library currently does not touch any other files. Though I try very hard to fix bugs and use the library myself, I cannot guarantee your files won't go up in flames, particularly if you are using a non-standard file structure or encoding. If something does go wrong, please file an issue.
  • Certain formattings will be lost. For example, attributes (like #ARTIST) will always be converted to uppercase. Same goes for empty lines in the attributes section. The current goal is to be able to parse files that adhere to the Official Ultrastar Format Specification. For everything else, a best effort is made.

Features

from ultrastarparser import Song, Library
song = Song('path_to_txt_file')
song.get_attribute('ARTIST') # Returns song artist
song.set_attribute('ARTIST', 'Bon Jovi') # Set song artist
song.set_version('1.1.0') # Set song file version. See https://usdx.eu/format.
song.flush() # Flush changes made to the file system. 

lib = Library('path_to_library')
for s in lib:
    # check for somthing in every song
songs_by_bon_jovi = lib.search('ARTIST', 'Bon Jovi') # Returns all songs with Bon Jovi as artist
lib.export('export_path', 'json') # exports library to path as certain format. 

Planned features

  • Ability to backup files, for example before overwriting
  • Logging
  • Better error handling (and documentation of error handling)
  • Metadata extraction not from txt file (e.g. song duration from audio file or video resolution from video file)

Unplanned features

  • Editing the songtext and notes

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

ultrastarparser-0.6.1.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

ultrastarparser-0.6.1-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file ultrastarparser-0.6.1.tar.gz.

File metadata

  • Download URL: ultrastarparser-0.6.1.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.2 Windows/11

File hashes

Hashes for ultrastarparser-0.6.1.tar.gz
Algorithm Hash digest
SHA256 35c382827ee9c6fbeed43c00711ae3517030c8ea4ded554b4e2785340f179792
MD5 ee62ad44ed21cc21b5a47950532d54a8
BLAKE2b-256 7e07c33b44af1d2f71f2f13b790367fcca46c6eedcdecfe156daa91f75f872d8

See more details on using hashes here.

File details

Details for the file ultrastarparser-0.6.1-py3-none-any.whl.

File metadata

File hashes

Hashes for ultrastarparser-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ca525146473cfaba8f0fa6c121c42a6f6d61c93b9501e1c0e52d202565cfb336
MD5 523c4e483d6c948470d55f8684e726ad
BLAKE2b-256 08d8fa039c6688baa697ec9b93f255b1b9b204f3356dfe0ea68c4782d74309fa

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