Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/senzmaki/senpwai
A desktop app for tracking and batch downloading anime
https://github.com/senzmaki/senpwai
anime anime-downloader anime-scraper anime-tracker automation batch-downloader beautifulsoup bulk-downloader cross-platform pyqt pyqt6-desktop-application python tracker web-scraper
Last synced: 2 days ago
JSON representation
A desktop app for tracking and batch downloading anime
- Host: GitHub
- URL: https://github.com/senzmaki/senpwai
- Owner: SenZmaKi
- License: gpl-3.0
- Created: 2023-03-16T15:25:28.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-12-27T18:59:41.000Z (25 days ago)
- Last Synced: 2025-01-12T18:03:45.581Z (9 days ago)
- Topics: anime, anime-downloader, anime-scraper, anime-tracker, automation, batch-downloader, beautifulsoup, bulk-downloader, cross-platform, pyqt, pyqt6-desktop-application, python, tracker, web-scraper
- Language: Python
- Homepage: https://youtu.be/dQw4w9WgXcQ
- Size: 94.5 MB
- Stars: 214
- Watchers: 6
- Forks: 22
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
Senpwai
A blazingly fast desktop app for batch downloading anime and auto-downloading new episodes upon release
Installation •
Features •
CLI •
Building from source •
Support •
FAQ •
Links •
Contribution## Installation
- **Windows 10/11**
Download [the setup](https://github.com/SenZmaKi/Senpwai/releases/latest/download/Senpwai-setup.exe) then run it. (Recommended)
- **Cross-platform (Linux, Mac, Windows 10/11)**
Needs [Python 3.11](https://www.python.org/downloads/release/python-3119)+ installed.
```bash
pip install senpwai
```- **Android**
Check [Senpcli](https://github.com/SenZmaKi/Senpwai/blob/master/docs/senpcli-guide.md)
- **Other**
[Build from source](#building-from-source).
## Features
- Download any anime from [Animepahe](https://animepahe.ru) or [Gogoanime](https://anitaku.so).
- Keep track of an anime and automatically download new episodes when they release.
- Download a complete season or episodes within a range (e.g., 69-420).
- Choose between video qualities: 360p, 480p (Gogoanime only), 720p, or 1080p.
- Download in sub or dub (if available) depending on the user's preference.
- Automatically detects episodes you already have and avoids re-downloading them.
- Robust and graceful download error management.
- GUI and [CLI](https://github.com/SenZmaKi/Senpwai/blob/master/docs/senpcli-guide.md).## CLI
[Senpcli](https://github.com/SenZmaKi/Senpwai/blob/master/docs/senpcli-guide.md) is a CLI alternative for Senpwai. Senpwai is already efficient and lightweight, Senpcli basically strips off the GUI while maintaining most of the basic functionality.
## Support
- You can support the development of Senpwai through donations on [GitHub Sponsors](https://github.com/sponsors/SenZmaKi) or [Patreon](https://patreon.com/Senpwai).
- You can also leave a star on the github for more weebs to know about it.
- Senpwai is open to pull requests, so if you have ideas for improvements, feel free to [contribute](#contribution)!## Sponsors
## Building from Source
Ensure you have [Python 3.11](https://www.python.org/downloads/release/python-3119) (3.11 specifically!!!) and [Git](https://github.com/git-guides/install-git) installed.
Open a terminal and run the following commands.
1. **Set everything up.**
```
git clone https://github.com/SenZmaKi/Senpwai --depth 1 && cd Senpwai && pip install -r dev-requirements.txt && poetry install
```2. **Build the app into an executable.**
```
poetry run poe build_senpwai_exe
```- The executable will be built in `Senpwai\build\Senpwai`
3. **Alternatively you can instead run the app directly via Python.**
- Activate virtual environment
```
poetry shell
```- Run the app
```
python -m senpwai
```- Both steps at once, but it is slower since it activates the virtual environment every time
```
poetry run senpwai
```## FAQ
Why did you make this?
I couldn't afford wifi so I used my college wifi to batch download anime after class but batch downloading from streaming sites is a pain in the ass,
you have to click billions of links just to download one episode, so I made Senpwai to help me and possibly others that face a similar problem.What is HLS mode?
HLS mode attempts to fix the unstability of Gogoanime normal mode.
In HLS mode Gogoanime downloads are guaranteed to work, though with a few downsides:- Requires [FFmpeg](https://www.hostinger.com/tutorials/how-to-install-ffmpeg) to be installed, though Senpwai can attempt to automatically install it for you.
- No download size indication but Senpwai will estimate the total download size after the first download.Do you intend to add more sources?
One person can only do so much, I only plan on adding another source if something ever happens to Animepahe or Gogoanime.
More sources means more writing more code which in turn means fixing more bugs.## Links
[Discord server](https://discord.com/invite/e9UxkuyDX2)
[Subreddit](https://reddit.com/r/Senpwai)
[GitHub Sponsors](https://github.com/sponsors/SenZmaKi)
[Patreon](https://patreon.com/Senpwai)
## Contribution
- If it's a change to code e.g., `main.py` make the pull request into the most recent branch e.g., `v2.1.5` instead of `master`.
- If it's a change to documentation e.g., `README.md` make the pull request into the `master` branch.
- If you open the project folder on [Visual Studio Code](https://code.visualstudio.com/) you will be prompted to install recommended extensions for the project.
- [Pyright](https://github.com/microsoft/pyright) is used as the type checker, ensure your code is type annotated well and there are no type errors.
- [Ruff](https://github.com/astral-sh/ruff) is used for formatting and linting.
- [Inno Setup](https://jrsoftware.org/isinfo.php) is used for creating the installer, add the installation folder to the `%PATH%` environment variable for access to `ISCC.exe` from the command line. Also set the `SENPWAI_ROOT_DIR` environment variable to the root directory of the project.
- [Poe](https://github.com/nat-n/poethepoet) is used as the task runner, there are various tasks available to run e.g., `poe lint` to lint the code. It autoloads the `.env` file in the root directory of the project. Poe is installed when you setup the project.## Legal Disclaimer
Senpwai is designed solely for providing access to publicly available content. It is not intended to support or promote piracy or copyright infringement. As the creator of this app, I hereby declare that I am not responsible for, and in no way associated with, any external links or the content they direct to.
It is essential to understand that all the content available through this app are found freely accessible on the internet and the app does not host any copyrighted content. I do not exercise control over the nature, content, or availability of the websites linked within the app.
If you have any concerns or objections regarding the content provided by this app, please contact the respective website owners, webmasters, or hosting providers. Thank you.
## Epilogue
Truly one of the most apps ever of all time.