Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lysagxra/pixivdownloader
Efficient downloader for Pixiv albums
https://github.com/lysagxra/pixivdownloader
bulk bulk-download concurrent-processing downloader parallel-processing pixiv pixiv-downloader python python3
Last synced: about 2 months ago
JSON representation
Efficient downloader for Pixiv albums
- Host: GitHub
- URL: https://github.com/lysagxra/pixivdownloader
- Owner: Lysagxra
- License: agpl-3.0
- Created: 2024-10-26T22:39:10.000Z (2 months ago)
- Default Branch: main
- Last Pushed: 2024-11-12T22:49:19.000Z (about 2 months ago)
- Last Synced: 2024-11-12T23:29:06.573Z (about 2 months ago)
- Topics: bulk, bulk-download, concurrent-processing, downloader, parallel-processing, pixiv, pixiv-downloader, python, python3
- Language: Python
- Homepage:
- Size: 17.5 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Pixiv Downloader
> A Python-based tool for downloading Pixiv albums. This tool reads a list of URLs from a file, checks against a record of already downloaded albums to avoid duplicates, and processes the downloads accordingly.
![Demo](https://github.com/Lysagxra/PixivDownloader/blob/01e060c7bd40f0df1a45c85185955b48aa0e58e6/misc/Demo.gif)
## Features
- Downloads multiple files concurrently.
- Supports batch downloading via a list of URLs.
- Tracks download progress with a progress bar.
- Avoid duplicats by comparing URLs against a record of already downloaded albums.
- Automatically creates a directory structure for organized storage.## Dependencies
- Python 3
- `Pillow` - for image processing and manipulation.
- `BeautifulSoup` (bs4) - for HTML parsing
- `requests` - for HTTP requests
- `rich` - for progress display in the terminal.## Directory Structure
```
project-root/
├── helpers/
│ ├── download_utils.py # Utilities for managing the download process
│ ├── file_utils.py # Utilities for managing file operations
│ ├── general_utils.py # Miscellaneous utility functions
│ ├── pixiv_utils # Functions for handling Pixiv-related tasks
│ └── progress_utils.py # Tools for progress tracking and reporting
├── album_downloader.py # Module for downloading Pixiv albums
├── main.py # Main script to run the downloader
├── URLs.txt # Text file containing album URLs
└── already_downloaded.txt # File to record downloaded albums
```## Installation
1. Clone the repository:
```bash
git clone https://github.com/Lysagxra/PixivDownloader.git
```2. Navigate to the project directory:
```bash
cd PixivDownloader
```3. Install the required dependencies:
```bash
pip install -r requirements.txt
```## Single Album Download
To download a single album from an URL, you can use `album_downloader.py`, running the script with a valid album URL.
### Usage
```bash
python3 album_downloader.py
```### Example
```
python3 album_downloader.py https://www.pixiv.net/en/artworks/122835267
```## Batch Download
To batch download from multiple album URLs, you can use the `main.py` script. This script reads URLs from a file named `URLs.txt` and downloads each one using the album downloader.
### Usage
1. Create a file named `URLs.txt` in the root of your project, listing each URL on a new line.
2. Run the batch download script:
```
python3 main.py
```3. The downloaded files will be saved in the `Downloads` directory.
## Logging
The application append the downloaded albums in a file named `already_downloaded.txt` to avoid duplicates.