Awesome
xvideos-dl
<div align="center">CLI to download videos from https://xvideos.com
</div> <div align="center"><a href="https://github.com/lonsty/xvideos-dl/blob/master/README_CN.md">中文文档</a></div>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.1ffmpeg
- Ubuntu/Debian:
sudo apt install ffmpeg
- MacOS:
brew install ffmpeg
- Windows: refer this issue
- Ubuntu/Debian:
Cookie
: When you run it for the first time, you will be prompted to enter the cookie, log in https://xvideos.com with your account, copy and paste a long string of cookie (there are many key-value pairs in the cookie, andsession_token=xxx
this pair must exist), then enjoy it.
Cookie is stored in ~/.xvideos/cookie (or C:\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
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 low
or-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.
<hr>For Contributors
Initial
- Fork and clone this repo:
git clone https://github.com/lonsty/xvideos-dl
- If you don't have
Poetry
installed run:
make download-poetry
- Initialize poetry and install
pre-commit
hooks:
make install
Makefile usage
Makefile
contains many functions for fast assembling and convenient work.
make download-poetry
</p>
</details>
<details>
<summary>2. Install all dependencies and pre-commit hooks</summary>
<p>
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
</p>
</details>
<details>
<summary>3. Check the security of your code</summary>
<p>
make check-safety
This command launches a Poetry
and Pip
integrity check as well as identifies security issues with Safety
and Bandit
. By default, the build will not crash if any of the items fail. But you can set STRICT=1
for the entire build, or you can configure strictness for each item separately.
make check-safety STRICT=1
or only for safety
:
make check-safety SAFETY_STRICT=1
multiple
make check-safety PIP_STRICT=1 SAFETY_STRICT=1
</p> </details> <details> <summary>4. Check the codestyle</summary> <p>List of flags for
check-safety
(can be set to1
or0
):STRICT
,POETRY_STRICT
,PIP_STRICT
,SAFETY_STRICT
,BANDIT_STRICT
.
The command is similar to check-safety
but to check the code style, obviously. It uses Black
, Darglint
, Isort
, and Mypy
inside.
make check-style
It may also contain the STRICT
flag.
make check-style STRICT=1
</p> </details> <details> <summary>5. Run all the codestyle formaters</summary> <p>List of flags for
check-style
(can be set to1
or0
):STRICT
,BLACK_STRICT
,DARGLINT_STRICT
,ISORT_STRICT
,MYPY_STRICT
.
Codestyle uses pre-commit
hooks, so ensure you've run make install
before.
make codestyle
</p>
</details>
<details>
<summary>6. Run tests</summary>
<p>
make test
</p>
</details>
<details>
<summary>7. Run all the linters</summary>
<p>
make lint
the same as:
make test && make check-safety && make check-style
</p> </details> <details> <summary>8. Build docker</summary> <p>List of flags for
lint
(can be set to1
or0
):STRICT
,POETRY_STRICT
,PIP_STRICT
,SAFETY_STRICT
,BANDIT_STRICT
,BLACK_STRICT
,DARGLINT_STRICT
,ISORT_STRICT
,MYPY_STRICT
.
make docker
which is equivalent to:
make docker VERSION=latest
More information here.
</p> </details> <details> <summary>9. Cleanup docker</summary> <p>make clean_docker
or to remove all build
make clean
More information here.
</p> </details>📈 Releases
You can see the list of available releases on the GitHub Releases page.
We follow Semantic Versions specification.
We use Release 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 in release-drafter.yml
.
GitHub creates the bug
, enhancement
, and documentation
labels for you. Dependabot creates the dependencies
label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.
🛡 License
This project is licensed under the terms of the MIT
license. See LICENSE for 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 with python-package-template
.