Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/maxhalford/chime
🎵 Python sound notifications made easy
https://github.com/maxhalford/chime
audio command-line cross-platform ipython notifications python sound streamlit wav
Last synced: 6 days ago
JSON representation
🎵 Python sound notifications made easy
- Host: GitHub
- URL: https://github.com/maxhalford/chime
- Owner: MaxHalford
- License: mit
- Created: 2020-10-04T17:34:48.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2023-03-06T22:25:50.000Z (almost 2 years ago)
- Last Synced: 2025-01-24T23:11:42.227Z (6 days ago)
- Topics: audio, command-line, cross-platform, ipython, notifications, python, sound, streamlit, wav
- Language: Python
- Homepage: https://chime-soundboard.streamlit.app
- Size: 4.98 MB
- Stars: 306
- Watchers: 3
- Forks: 13
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
chime
Python sound notifications made easy.
## Table of contents
- [Table of contents](#table-of-contents)
- [Motivation](#motivation)
- [Installation](#installation)
- [Basic usage](#basic-usage)
- [Theming](#theming)
- [IPython/Jupyter magic](#ipythonjupyter-magic)
- [Exception notifications](#exception-notifications)
- [Command-line usage](#command-line-usage)
- [Platform support](#platform-support)
- [I can't hear anything 🙉](#i-cant-hear-anything-)
- [Setting a default theme](#setting-a-default-theme)
- [Command-line arguments](#command-line-arguments)
- [Adding a new theme](#adding-a-new-theme)
- [Things to do](#things-to-do)
- [Acknowledgements](#acknowledgements)
- [License](#license)## Motivation
I made this because I wanted a simple auditory cue system to tell me when a long-running number crunching script had finished. I didn't want to have to fiddle with the command-line, and also wanted a cross-platform solution. Thus was born `chime`!
## Installation
```sh
pip install chime
```This library has **no dependencies**. The IPython/Jupyter functionality is only imported if you've installed the `ipython` library. It should work for any Python version above or equal to 3.6.
## Basic usage
`chime` puts four functions at your disposal:
```py
>>> import chime>>> chime.success()
>>> chime.warning()
>>> chime.error()
>>> chime.info()```
Calling any of the above functions will play a sound. Note that the sounds are played in asynchronous processes, and are thus non-blocking. Each function should take around 2ms to execute, regardless of the sound length. You're free to use each sound notification in any way you see fit. I'm not your mama.
## Theming
The sounds that are played depend on which theme is being used.
```py
>>> chime.theme() # return the current theme
'chime'```
Several themes are available:
```py
>>> chime.themes()
['big-sur', 'chime', 'future', 'mario', 'material', 'pokemon', 'sonic', 'zelda']```
The theme can be changed by passing a theme name to the `theme` function:
```py
>>> chime.theme('zelda')```
A couple of things to note:
- You can listen to the sounds interactively via [this soundboard](https://chime-soundboard.streamlit.app/), which is made with [Streamlit](https://www.streamlit.io/).
- A random theme will be picked each time you play a sound if you set the theme to `'random'`.## IPython/Jupyter magic
Load the extension as so:
```py
%load_ext chime
```You can wrap a line:
```py
%chime print("I'm a line")
```You can also wrap an entire cell:
```py
%%chimeprint("I'm a cell")
```The magic command will call `chime.success` when the line/cell finishes successfully. Otherwise, `chime.error` is called whenever an exception is raised.
## Exception notifications
If you run `chime.notify_exceptions`, then `chime.error` will be called whenever an exception is raised.
```py
chime.notify_exceptions()raise ValueError("I'm going to make some noise")
```## Command-line usage
You can run `chime` from the command-line:
```sh
$ chime
```By default, this will play the success sound. You can also choose which sound to play, like so:
```sh
$ chime info
```You can also choose which theme to use:
```sh
$ chime info --theme zelda
```If you're using bash, then you can use `chime` to notify you when a program finishes:
```sh
$ echo "Hello world!"; chime
```This will play the sound regardless of the fact that the first command succeeded or not. If you're running on Windows, then you can run the following equivalent:
```sh
> echo "Hello world!" & chime
```## Platform support
Under the hood, `chime` runs a command in the shell to play a `.wav` file. The command-line program that is used depends on the [platform](https://www.wikiwand.com/en/Computing_platform) that you're using. Platform information is available in the [`sys.platform` variable](https://docs.python.org/3/library/sys.html#sys.platform) as well as the [`platform` module](https://docs.python.org/3/library/platform.html) from the standard library. Currently, the supported platforms are:
- Darwin
- Linux
- WindowsA `UserWarning` is raised if you run a `chime` sound on an unsupported platform. Feel free to get in touch or issue a pull request if you want to add support for a specific platform. Likewise, don't hesitate if you're encountering trouble with one of the above platforms. I won't bite.
## I can't hear anything 🙉
Did you check if you turned your sound on? Just kidding. 😜
This library is designed to be non-invasive. By default, sounds are played asynchronously in unchecked processes. Therefore, if something goes wrong, the process dies silently. If you can't hear anything and you think that the issue is coming from `chime`, then set the `sync` parameter when you play a sound:
```py
>>> chime.info(sync=True)```
This will play the sound synchronously and issue a warning if something goes wrong, which should allow you to debug the issue. You can also raise an exception instead of sending a warning by setting the `raise_error` parameter:
```py
>>> chime.info(sync=True, raise_error=True)```
Note that setting `raise_error` won't do anything if `sync` is set to `False`.
## Setting a default theme
To change the default theme a configuration file may be created in `~/.config/chime/chime.conf` on Unix or `%APPDATA%\chime\chime.ini` on Windows.
For example, to change the default theme to `'zelda'`, the configuration file would contain:
```ini
[chime]
theme = zelda```
## Command-line arguments
Chime works by running commands in the CLI. For instance, `aplay` is used on Linux systems, while `afplay` is used on Darwin systems. Arguments can be specified by setting the `RUN_ARGS` variable. For example, here's how to select a specific sound card, assuming a Linux system using `aplay`:
```py
>>> chime.RUN_ARGS = "--device sysdefault:CARD=PCH"```
You can also specify this as a default configuration in the configuration file:
```ini
[chime]
cli_args = '--device sysdefault:CARD=PCH'```
At present, it isn't possible to pass CLI arguments on Windows, due to a limitation of the [`winsound`](https://docs.python.org/3/library/winsound.html) module.
## Adding a new theme
I have toyed with the idea of allowing users to add their own theme(s), but at the moment I rather keep things minimal. However, I'm happy to integrate new themes into the library. You can propose a new theme by [opening a pull request](https://github.com/MaxHalford/chime/issues/new) that adds the necessary .wav files to the [`themes` directory](https://github.com/MaxHalford/chime/tree/main/themes). A theme is made up of four files: `success.wav`, `warning.wav`, `error.wav`, and `info.wav`. That's all you need to do: the theme will picked up be automatically once the necessary files are provided.
Be creative! 👩🎨
## Things to do
- Some mechanism to automatically call `chime.warning` when a warning occurs.
- Make it work with a remote machine. For instance a Jupyter Notebook hosted on a remote machine.
- More themes!## Acknowledgements
- Special thanks to [Michael Vlah](https://github.com/vlahm) for being a gentleman by giving up the "chime" name on PyPI.
- Thanks to u/Pajke on reddit for helping me debug Windows support.
- Thanks to [David Chen](https://github.com/dchen327) for adding Linux support by suggesting the use of [aplay](https://linux.die.net/man/1/aplay).
- Thanks to [Vincent Warmerdam](https://twitter.com/fishnets88) for suggesting a command-line interface.
- Calmcode made a [video introduction to chime](https://calmcode.io/chime/introduction.html) ❤️
- Thanks to [Paulo S. Costa](https://github.com/paw-lu) for contributing in many different ways.
- Thanks to [d34d_m8](https://github.com/d34dm8) for adding OpenBSD support.## License
As you would probably expect, this is [MIT licensed](LICENSE).