Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mps-youtube/yewtube
yewtube, forked from mps-youtube , is a Terminal based YouTube player and downloader. No Youtube API key required.
https://github.com/mps-youtube/yewtube
Last synced: 1 day ago
JSON representation
yewtube, forked from mps-youtube , is a Terminal based YouTube player and downloader. No Youtube API key required.
- Host: GitHub
- URL: https://github.com/mps-youtube/yewtube
- Owner: mps-youtube
- License: gpl-3.0
- Created: 2014-02-03T04:17:46.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2024-09-11T12:03:36.000Z (4 months ago)
- Last Synced: 2024-10-29T15:07:35.345Z (3 months ago)
- Language: Python
- Homepage:
- Size: 2.98 MB
- Stars: 8,105
- Watchers: 187
- Forks: 643
- Open Issues: 211
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hacking-lists - mps-youtube/yewtube - yewtube, forked from mps-youtube , is a Terminal based YouTube player and downloader. No Youtube API key required. (Python)
README
![](https://img.shields.io/pypi/v/yewtube.svg) ![](https://img.shields.io/pypi/wheel/yewtube.svg)
## STOP GENOCIDE OF INNOCENT PEOPLE
![](https://upload.wikimedia.org/wikipedia/commons/thumb/0/00/Flag_of_Palestine.svg/1280px-Flag_of_Palestine.svg.png)
_ _
| | | |
_ _ _____ _| |_ _ _| |__ ___
| | | |/ _ \ \ /\ / / __| | | | '_ \ / _ \
| |_| | __/\ V V /| |_| |_| | |_) | __/
\__, |\___| \_/\_/ \__|\__,_|_.__/ \___|
__/ |
|___/yewtube, forked from mps-youtube , is a Terminal based YouTube player and downloader. No Youtube API key required.
Visit [this](./COLLABORATORS.md) page if you want to support maintainers of this project.Installation
-----------
# Stable Version### Using pip
1. Install using `pip install yewtube`
2. Run using, `yt`. Enjoy!### Using pipx (Recommended)
1. Install **_pipx_** using `pip install pipx`
2. Install `yewtube` using `pipx install yewtube`
3. Now, type `yt` That's it.# Latest Version
### Using pip
1. Install using `pip install git+https://github.com/mps-youtube/yewtube.git`
2. Run using, `yt`. Enjoy!### Using pipx
1. Install **_pipx_** using `pip install pipx`
2. Install `yewtube` using `pipx install git+https://github.com/mps-youtube/yewtube.git`
3. Now, type `yt` That's it.What's new in yewtube?
----------------------
- **No Youtube API Key required**
- **Run audio in VLC with no GUI**See complete and up-to-date changelog [here](https://github.com/mps-youtube/yewtube/blob/master/CHANGELOG.md).
These features are still inherited from [mps-youtube](https://github.com/mps-youtube/mps-youtube).
- Search and play audio/video from YouTube
- Search tracks of albums by album title
- Search and import YouTube playlists
- Create and save local playlists
- Download audio/video
- Convert to mp3 & other formats (requires ffmpeg or avconv)
- View video comments
- Works with Python 3.x
- Works with Windows, Linux and Mac OS X
- Requires mplayer, mpv or VLCThis project is based on [mps-youtube](https://github.com/mps-youtube/mps-youtube) and mps-youtube is based on [mps](https://web.archive.org/web/20180429034221/https://github.com/np1/mps), a terminal based program to search, stream and download music. This
implementation uses YouTube as a source of content and can play and
download video as well as audio. The [pafy](https://github.com/mps-youtube/pafy) library handles interfacing with YouTube.[mps-youtube wiki](https://github.com/mps-youtube/mps-youtube/wiki/Troubleshooting)
[yewtube wiki](https://github.com/mps-youtube/yewtube/wiki/FAQ)Screenshots
-----------Search:
![](http://mps-youtube.github.io/yewtube/std-search.png)A standard search is performed by entering `/` followed by search terms.
You can play all of the search results by giving `1-` as input
Repeating song/songs can be done with `song_number[loop]`, for example:
`1[3]` or `4-6[2]`Local Playlists:
![](http://mps-youtube.github.io/yewtube/local-playlist.png)Search result items can easily be stored in local playlists.
YouTube Playlists:
![](http://mps-youtube.github.io/yewtube/playlist-search.png)YouTube playlists can be searched and played or saved as local
playlists.A playlist search is performed by `//` followed by search term.
Download:
![](http://mps-youtube.github.io/yewtube/download.png)Content can be downloaded in various formats and resolutions.
Comments:
![](http://mps-youtube.github.io/yewtube/comments.png)A basic comments browser is available to view YouTube user comments.
Music Album Matching:
![](http://mps-youtube.github.io/yewtube/album-1.png)
![](http://mps-youtube.github.io/yewtube/album-2.png)
An album title can be specified and yewtube will attempt to find
matches for each track of the album, based on title and duration. Type
`help search` for more info.Customisation:
![](http://mps-youtube.github.io/yewtube/customisation2.png)
Search results can be customised to display additional fields and
ordered by various criteria.This configuration was set up using the following commands
```
set order views
set columns user:14 date comments rating likes dislikes category:9 views
```Type `help config` for help on configuration options
Upgrading
---------### If installed using pipx
`pipx upgrade yewtube`
Optionally with upgrading all dependencies:
`pipx runpip yewtube install --upgrade-strategy eager --upgrade yewtube`
### If installed using pip
`pip install --upgrade yewtube`
Optionally with upgrading all dependencies:
`pip install --upgrade-strategy eager --upgrade yewtube`
Usage
-----yewtube is run on the command line using the command:
`yt`
Enter `h` from within the program for help.
Using yewtube with mpv
----------------------If you have `mpv` player installed and you set it to be used as the player
you can have yewtube to use its input bindings (with only a few usability changes
done automatically by yewtube) by soft-linking to it from `~/.config/mps-youtube/mpv-input.conf`
like so:```shell
> ln -sr ~/.config/mpv/input.conf ~/.config/mps-youtube/mpv-input.conf
```Using yewtube with mpris
------------------------1. Install PyGObject, GTK and their dependencies based on this guide https://pygobject.readthedocs.io/en/latest/getting_started.html
2. Install yewtube with mpris extra```shell
> # recommended
> pipx install 'yewtube[mpris]'
> # or
> pip install 'yewtube[mpris]'
```3. check yewtube version
```shell
> yt --version
yewtube version : 2.8.2
yt_dlp version : 2022.02.04
Python version : 3.9.7 (default, Nov 7 2021, 15:17:57)
[GCC 11.2.0]
Processor : x86_64
Machine type : x86_64
Architecture : 64bit, ELF
Platform : Linux-5.13.0-35-generic-x86_64-with-glibc2.34
sys.stdout.enc : utf-8
default enc : utf-8
Config dir : /home/user/.config/mps-youtube
dbus : 1.2.18
glib : True
env:TERM : tmux-256color
env:SHELL : /usr/bin/zsh
env:LANG : en_US.UTF-8
```If everything working correctly, dbug and glib would have similar result as above text
4. run `set mpris true` on yewtube
5. check with `playerctl````shell
> playerctl -l
mps-youtube.instance567867
```Check also the [common-issue](https://github.com/mps-youtube/yewtube/wiki/Common-issues) if you are having problem with yewtube.
How to Contribute
-----------------Contributions are warmly welcomed! However, please check out the [contribution page](https://github.com/mps-youtube/yewtube/blob/master/CONTRIBUTING.md) before making a contribution.