Skip to content

lonsty/xvideos-dl

Repository files navigation

xvideos-dl

Build status Python Version Dependencies Status

Code style: black Security: bandit Pre-commit Semantic Versions License

CLI to download videos fromhttps://xvideos.com

Features

  • Download a single video (requires the URL of the video playback page)
  • Download all videos in the favorites (requires the URL of the favorite page)
  • Download all videos uploaded by the user (requires the URL of the user's homepage)
  • Download all videos published by the channel (requires the URL of the channel homepage)
  • Segmented high-speed download, breakpoint download, progress and status display
  • Download high quality videos, 1080p or higher

Usage

⚠️Requires:

  • Python:>= 3.6.1
  • ffmpeg
    • Ubuntu/Debian:sudo apt install ffmpeg
    • MacOS:brew install ffmpeg
    • Windows: refer thisissue
  • Cookie:When you run it for the first time, you will be prompted to enter the cookie, log inhttps://xvideos.comwith your account, copy and paste a long string of cookie (there are many key-value pairs in the cookie, andsession_token=xxxthis pair must exist), then enjoy it.

Cookie is stored in~/.xvideos/cookie(orC:\Users\USER\.xvideos\cookie).

  • Install xvideos-dl
pip install -U xvideos-dl
  • Get CLI help
xvideos-dl --help
  • Download single / favorites / uploaded / published videos in one command:
xvideos-dl https://www.xvideos.com/video37177493/asian_webcam_2_camsex4u.life https://www.xvideos.com/favorite/71879935/_ https://www.xvideos.com/profiles/mypornstation https://www.xvideos.com/channels/av69tv

demo

Release History

1.3.0

  • Added support for downloading higher quality videos.

    CLI will download the highest quality video by default, which may be 1080p or higher, depending on the videos provided by XVIDEOS. So the download speed will be slower, if you want to be faster, you can use-q lowor-q middle.

1.2.0

  • Support for Python 3.6.1+

1.1.2

Bugfix:

  • Fixed a bug that would not retry when the network connection failed.

1.1.1

New Feature:

  • Add parameters to control the start and end of the video in the download list.

Others:

  • When running the same command repeatedly, quickly skip the downloaded video.
  • Catch exceptions: 404 not found, forbidden downloading...

1.1.0

New Features:

  • Download all videos uploaded by users.
  • Download all videos posted by the channel.
  • Download single, playlist, user uploaded and channel posted videos in one command.
  • Optimize download status display.

1.0.1

New Features:

  • Download videos from favorites.
  • Show download speed.

1.0.0

Initial release on PyPY.


For Contributors

Initial

  1. Fork and clone this repo:
git clone https://github.com/lonsty/xvideos-dl
  1. If you don't havePoetryinstalled run:
make download-poetry
  1. Initialize poetry and installpre-commithooks:
make install

Makefile usage

Makefilecontains many functions for fast assembling and convenient work.

1. Download Poetry

make download-poetry

2. Install all dependencies and pre-commit hooks

make install

If you do not want to install pre-commit hooks, run the command with the NO_PRE_COMMIT flag:

make install NO_PRE_COMMIT=1

3. Check the security of your code

make check-safety

This command launches aPoetryandPipintegrity check as well as identifies security issues withSafetyandBandit.By default, the build will not crash if any of the items fail. But you can setSTRICT=1for the entire build, or you can configure strictness for each item separately.

make check-safety STRICT=1

or only forsafety:

make check-safety SAFETY_STRICT=1

multiple

make check-safety PIP_STRICT=1 SAFETY_STRICT=1

List of flags forcheck-safety(can be set to1or0):STRICT,POETRY_STRICT,PIP_STRICT,SAFETY_STRICT,BANDIT_STRICT.

4. Check the codestyle

The command is similar tocheck-safetybut to check the code style, obviously. It usesBlack,Darglint,Isort,andMypyinside.

make check-style

It may also contain theSTRICTflag.

make check-style STRICT=1

List of flags forcheck-style(can be set to1or0):STRICT,BLACK_STRICT,DARGLINT_STRICT,ISORT_STRICT,MYPY_STRICT.

5. Run all the codestyle formaters

Codestyle usespre-commithooks, so ensure you've runmake installbefore.

make codestyle

6. Run tests

maketest

7. Run all the linters

make lint

the same as:

maketest&&make check-safety&&make check-style

List of flags forlint(can be set to1or0):STRICT,POETRY_STRICT,PIP_STRICT,SAFETY_STRICT,BANDIT_STRICT,BLACK_STRICT,DARGLINT_STRICT,ISORT_STRICT,MYPY_STRICT.

8. Build docker

make docker

which is equivalent to:

make docker VERSION=latest

More informationhere.

9. Cleanup docker

make clean_docker

or to remove all build

make clean

More informationhere.

📈 Releases

You can see the list of available releases on theGitHub Releasespage.

We followSemantic Versionsspecification.

We useRelease Drafter.As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when you’re ready. With the categories option, you can categorize pull requests in release notes using labels.

For Pull Request this labels are configured, by default:

Label Title in Releases
enhancement,feature 🚀 Features
bug,refactoring,bugfix,fix 🔧 Fixes & Refactoring
build,ci,testing 📦 Build System & CI/CD
breaking 💥 Breaking Changes
documentation 📝 Documentation
dependencies ⬆️ Dependencies updates

You can update it inrelease-drafter.yml.

GitHub creates thebug,enhancement,anddocumentationlabels for you. Dependabot creates thedependencieslabel. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.

🛡 License

License

This project is licensed under the terms of theMITlicense. SeeLICENSEfor more details.

📃 Citation

@misc{xvideos-dl,
author = {xvideos-dl},
title = {CLI to download videos from https://xvideos.com},
year = {2021},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/lonsty/xvideos-dl}}
}

Credits

This project was generated withpython-package-template.

About

CLI to download videos fromhttps://xvideos.com| H phiến hạ tái công cụ 😘

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published