Skip to main content

A Python library for playing sound everywhere natively and securely.

Project description

Overview

Nava is a Python library that allows users to play sound in Python without any dependencies or platform restrictions. It is a cross-platform solution that runs on any operating system, including Windows, macOS, and Linux. Its lightweight and easy-to-use design makes Nava an ideal choice for developers looking to add sound functionality to their Python programs.

PyPI Counter
Github Stars
Branch main dev
Linux CI
Windows CI
macOS CI
Code Quality CodeFactor codebeat badge

Installation

PyPI

Source code

Conda

Usage

Basic

from nava import play
play("alarm.wav")

Async mode

⚠️ The async_mode parameter has a default value of False

import time
from nava import play, stop
sound_id = play("alarm.wav", async_mode=True)
time.sleep(4)
stop(sound_id)

Loop mode

⚠️ The loop parameter has a default value of False ⚠️ You should always set async_mode flag when you are using loop

from nava import play, stop
sound_id = play("alarm.wav", async_mode=True, loop=True)
time.sleep(100)
stop(sound_id)

Error

from nava import play, NavaBaseError

try:
    play("alarm.wav")
except NavaBaseError as e:
    print(str(e))

Engine

List of different platforms and the corresponding engines that are used for sound playing.

Platform Engine Supported Formats
Linux Advanced Linux Sound Architecture .wav
Windows Winsound .wav
macOS Audio File Play .wav,.mp3

Issues & bug reports

Just fill an issue and describe it. We'll check it ASAP! or send an email to info@openscilab.com.

  • Please complete the issue template

You can also join our discord server

Discord Channel

Show your support

Star this repo

Give a ⭐️ if this project helped you!

Donate to our project

If you do like our project and we hope that you do, can you please support us? Our project is not and is never going to be working for profit. We need the money just so we can continue doing what we do ;-) .

Nava Donation

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

Unreleased

0.5 - 2024-04-03

Changed

  • loop parameter added to play function
  • NavaThread class modified
  • README.md modified

0.4 - 2024-02-19

Added

  • feature_request.yml template
  • config.yml for issue template

Changed

  • Bug report template modified
  • NavaThread.stop method bug fixed
  • Test system modified
  • README.md modified

0.3 - 2024-01-31

Added

  • NavaThread class
  • stop function
  • stop_all function

Changed

  • async_mode parameter added to play function
  • Test system modified
  • README.md modified
  • Python 3.12 added to linux_test.yml, macOS_test.yml and windows_test.yml

0.2 - 2023-07-10

Added

  • Logo
  • Anaconda package

Changed

  • quote decorator bug fixed
  • path_check decorator bug fixed
  • Test system modified
  • README.md modified

0.1 - 2023-06-10

Added

  • README.md
  • __play_win function
  • __play_linux function
  • __play_mac function
  • quote function
  • path_check function
  • play function

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

nava-0.5.tar.gz (10.5 kB view details)

Uploaded Source

Built Distribution

nava-0.5-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

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