Skip to main content

A Python implementation of VRipper

Project description

vripper

A Python implementation of VRipper. See the list of supported websites below.

Installation

# Python 3.6+
pip install vripper

Usage

from vripper import download_thread

if should_disable_logging:
    logging.getLogger("vripper").setLevel(logging.CRITICAL)

thread_url = "https://..."
dest = os.path.join(".", "vripper")

download_thread(thread_url, dest, **options)

Options

Not in any particular order

Name Type Default Value Description
mode vripper.enum
.downloadmode
.DownloadMode
FIRST_POST_ONLY Determines which post(s) within the thread to download.
output_format vripper.enum
.outputformat
.OutputFormat
None The desired output format. Currently supported: zip
download_threadpool_size int 5 The number of concurrent threads for the download. The minimum allowed value is 1.
processing_pool_size int multiprocessing
.cpu_count()
The number of concurrent processes for the pre/post-processing. Set it to 0 to disable multiprocessing.
max_filecount int None The max number of files (images) allowed in a post. If the number of files exceeds the given value, the module skip a subset of images. Ex. Download every 3rd image.
min_dimension int (pixels) 0 The min dimension allowed for an image. Images whose dimensions are smaller than this value will be deleted.
max_dimension int (pixels) None The max dimension allowed for an image. If the downloaded image exceeds the given value, the image will be resized.
max_filesize int (bytes) None Any files larger than this threshold will be deleted.
min_filesize int (bytes) None Any files smaller than this threshold will be deleted.
acceptable_filesize int (bytes) None Any files smaller than this threshold will not be considered for resize/compression. Expressed in bytes.
min_hitrate float .85 A minimum percentage of files in a post required to be downloaded and processed successfully.
download_connect_timeout float (seconds) 1.0 The time it takes to abort the connection with the image host.
download_read_timeout float (seconds) 10.0 The time it takes to abort the read with the image host.
compression_quality int 65 JPEG compression quality -- more info here. Set it to 0 to disable the compression. The value cannot be 0 if max_dimension has been specified.
processing_priority vripper.enum
.processingpriority
.ProcessingPriority
None Determines the course of action, given two conflicting options. Example TBD

Exceptions

For each image subject to download, there is a potential for the download to be considered unsuccessful. To name a few reasons:

  • Temporary network issues;
  • The host going offline temporarily or permanently;
  • The image was deleted by the uploader;
  • The downloaded file is corrupted; or
  • The downloaded file size is too small/big based on the user-specified threshold.

In the end, if the total number of successfully downloaded images does not meet min_hitrae, the module will throw one of the following exceptions:

Note: If the post has more images than the value specified in max_filecount, not all images will be subject to download. The skipped images will not be considered for the min_hitrate calculation.

Name Calculation Time Description
PermissionError Pre-download Raised when the requested thread is private.
UnsupportedHostError Pre-download Raised when the number of images hosted by unsupported websites is too high.
DeprecatedHostError Pre-download Raised when the number of images hosted by deprecated websites is too high.
ImagePermanentlyUnavailableError Post-download Raised when the number of deleted images is too high.
InsufficientFileCountError Final Raised when the number of resulting files in a post is too low.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vripper-0.5.28.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

vripper-0.5.28-py3-none-any.whl (30.5 kB view details)

Uploaded Python 3

File details

Details for the file vripper-0.5.28.tar.gz.

File metadata

  • Download URL: vripper-0.5.28.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for vripper-0.5.28.tar.gz
Algorithm Hash digest
SHA256 7b0c73d734d3fd37fe5cbe4c653143ec43cb44b75e2b61e9a346393003b5c2dd
MD5 4d181496f63599e3d01d966c27c0bc72
BLAKE2b-256 0d97b78fd1aa1280c80cdfd26024ae50b53618b5a20981e2a98af6ded9efb3d7

See more details on using hashes here.

File details

Details for the file vripper-0.5.28-py3-none-any.whl.

File metadata

  • Download URL: vripper-0.5.28-py3-none-any.whl
  • Upload date:
  • Size: 30.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for vripper-0.5.28-py3-none-any.whl
Algorithm Hash digest
SHA256 bde85085e6a232fe030bc2ba62ed1f17cf01d21dd955cf89f684063b04c382b2
MD5 f3862032c2e6544bb7a19a5d88523a3d
BLAKE2b-256 60c52a264d96a3eb0dadaa052e5e3c619e3a5740c76975edee27e2ba26912e1d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page