Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lagmoellertim/unsilence
Console Interface and Library to remove silent parts of a media file 🔈
https://github.com/lagmoellertim/unsilence
audio-processing contributions-welcome hacktoberfest media python silence-speedup silencedetect video-processing
Last synced: about 2 months ago
JSON representation
Console Interface and Library to remove silent parts of a media file 🔈
- Host: GitHub
- URL: https://github.com/lagmoellertim/unsilence
- Owner: lagmoellertim
- License: mit
- Created: 2020-06-09T19:49:57.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-03-28T04:57:13.000Z (almost 2 years ago)
- Last Synced: 2024-11-09T09:41:05.299Z (2 months ago)
- Topics: audio-processing, contributions-welcome, hacktoberfest, media, python, silence-speedup, silencedetect, video-processing
- Language: Python
- Homepage: https://unsilence.readthedocs.io/
- Size: 10.3 MB
- Stars: 555
- Watchers: 6
- Forks: 45
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- project-awesome - lagmoellertim/unsilence - Console Interface and Library to remove silent parts of a media file 🔈 (Python)
README
Unsilence
*
Console Interface and Library to remove silent parts of a media file
*---
### Demo
|Unedited (Before)|Processed by Unsilence (After)|
|:-:|:-:|
|[![Unedited Demo Video][unedited_demo_video_1_gif]][unedited_demo_video_1_vid]|[![Edited Demo Video][edited_demo_video_1_gif]][edited_demo_video_1_vid]|
|Time before edit: 0:09:45 (100%)| Time after edit: 0:07:56 (81.2%), Difference: -0:01:50 (-18.8%)|The MIT Intro at the beginning is not included into the time, since I left it in to show the license of the videos.
These videos are from this online lecture:
Ana Bell, Eric Grimson, and John Guttag. 6.0001 Introduction to Computer Science and Programming in Python. Fall 2016. Massachusetts Institute of Technology: MIT OpenCourseWare, https://ocw.mit.edu. License: Creative Commons BY-NC-SA.
More Information about Licensing can be found in the Licensing Segment of this README.
[unedited_demo_video_1_gif]: https://raw.githubusercontent.com/lagmoellertim/unsilence/master/media/unedited_demo.gif
[unedited_demo_video_1_vid]: https://youtu.be/wl7bveY5Ze4[edited_demo_video_1_gif]: https://raw.githubusercontent.com/lagmoellertim/unsilence/master/media/edited_demo.gif
[edited_demo_video_1_vid]: https://youtu.be/EaQh9cZ_jrs## Introduction
Unsilence is an **open-source tool** that **removes silence** from a media clip of your choice (audio, video).
You can use it to **speed up** videos without changing the audible speed, so you can understand everything, but get through a video **faster**.
### Exemplary use cases
- You are a college student and watch your lectures online (but have access to the video files). Instead of just increasing the playback speed to ~1.5x, you can remove
the parts that do not contain any value, like your lecturer thinking or waiting for something. But instead of cutting out these silent parts, speeding them up by a
different, much faster factor (think 6-8x) makes you still able to follow what is happening, so drawing or writing with no speech is sped up, which makes it far more pleasant to watch
- You want a video editor that automatically cuts any time you talk (or make any sound). That could be useful for manual time lapses
(you make a sound every time a short segment should be recorded), or for very fast jump cut videos with no manual editing required
- You want to have some fun and remove all the audible parts from a video, leaving only the parts where nearly silent noises are in the video (breathing, writing, ...)### Communication
If you have any (technical) questions about unsilence or want to get community feedback, you can use the new [GitHub Discussions Feature](https://github.com/lagmoellertim/unsilence/discussions/). To report a bug or suggest a new feature, create a new issue instead.### Usage Information
Unsilence can be used as a console line interface or as a python library, with which you can develop your own projects
### Prerequisites
- [Python](https://www.python.org/) >= 3.7.0
- [pip](https://pypi.org/) (should be installed automatically with python, could be different on some linux distros)
- [ffmpeg](https://ffmpeg.org/) >= 4.2.4In order to see the fancy progress bar and other terminal styling on windows, you should use [Windows Terminal](https://github.com/microsoft/terminal).
### Installation as command line interface (using pip and pipx)
```sh
# Installing pipx
pip install pipx# Installing Unsilence as Command Line Software
pipx install unsilence# If pipx asks you to, you also need to execute the following line
# as well as close and reopen your terminal window
pipx ensurepath
```### Installation as library (using pip)
```sh
# Installing Unsilence as Command Line Software
pip install unsilence
```### Installation as command line interface (from source)
```sh
# Clone the repository (stable branch)
git clone -b master https://github.com/lagmoellertim/unsilence.git unsilence#Change Directory
cd unsilence# Install pip packages
pip install -r requirements.txt
pip install pipx# Install unsilence package
pipx install .
```### Installation as library (from source)
```sh
# Clone the repository (stable branch)
git clone -b master https://github.com/lagmoellertim/unsilence.git unsilence#Change Directory
cd unsilence# Install pip packages
pip install -r requirements.txt# Install unsilence package
python3 setup.py install
```## Basic Command Line Usage
This generates a new file, where the silent parts are 6x as fast as before, the audible parts are the same speed as before
```sh
unsilence [input_file] [output_file]
```
You can change the speed of audible parts with `-as [speed]`, the speed of silent parts with `-ss [speed]`
```sh
unsilence [input_file] [output_file] -as [speed] -ss [speed]
```
You can change the volume of audible parts with `-av [volume]`, the volume of silent parts with `-sv [volume]`
```sh
unsilence [input_file] [output_file] -av [volume] -sv [volume]
```
To generate an audio only output file, you can add the `-ao` flag
```sh
unsilence [input_file] [output_file] -ao
```
To speed up the rendering process, you can increase the thread count using `-t [threads]`
```sh
unsilence [input_file] [output_file] -t [threads]
```
For many more settings, type `-h` or `--help`
```sh
unsilence --help
```## Basic Library Usage
Take a look at this [example](https://github.com/lagmoellertim/unsilence/blob/master/examples/basic_usage.py)## Idea/Inspiration
For this project, I took inspiration from the CaryKH's video [Jumpcutter](https://www.youtube.com/watch?v=DQ8orIurGxw).
This project does not share any source code with his implementation, and is more optimized for my use case (fast and efficient lecture silence removal).## Contributing
If you are missing a feature or have new idea, go for it! That is what open-source is for! 😃
## Author
**Tim-Luca Lagmöller** ([@lagmoellertim](https://github.com/lagmoellertim))
## Donations / Sponsors
I'm part of the official GitHub Sponsors program where you can support me on a monthly basis.
You can also contribute by buying me a coffee (this is a one-time donation).
Thank you for your support!
## License
The Code is licensed under the
[MIT License](https://github.com/lagmoellertim/unsilence/blob/master/LICENSE)
Copyright © 2019-present, [Tim-Luca Lagmöller](https://lagmoellertim.de)
All used videos are licensed under the
[Creative Commons BY-NC-SA License](https://ocw.mit.edu/terms/#cc)
## Have fun :tada: