gallery-dl/README.rst

349 lines
9.4 KiB
ReStructuredText
Raw Normal View History

2015-11-03 22:08:19 +01:00
==========
gallery-dl
==========
*gallery-dl* is a command-line program to download image galleries and
collections from several image hosting sites (see `Supported Sites`_).
It is a cross-platform tool with many configuration options
and powerful `filenaming capabilities <Formatting_>`_.
2016-07-25 11:13:54 +02:00
2015-11-03 22:08:19 +01:00
2018-01-09 15:10:40 +01:00
|pypi| |build| |gitter|
2017-01-25 02:31:36 +01:00
.. contents::
Dependencies
============
- Python_ 3.4+
- Requests_
Optional
--------
- FFmpeg_: Pixiv Ugoira to WebM conversion
2021-11-29 04:36:43 +01:00
- yt-dlp_ or youtube-dl_: Video downloads
- PySocks_: SOCKS proxy support
2017-01-25 02:31:36 +01:00
2015-11-03 22:08:19 +01:00
Installation
2015-11-10 21:13:43 +01:00
============
2015-11-03 22:08:19 +01:00
Pip
---
2017-05-09 15:43:55 +02:00
The stable releases of *gallery-dl* are distributed on PyPI_ and can be
2017-10-27 15:45:38 +02:00
easily installed or upgraded using pip_:
2017-05-09 15:43:55 +02:00
.. code:: bash
2022-03-11 02:48:10 +01:00
python3 -m pip install -U gallery-dl
2017-05-09 15:43:55 +02:00
Installing the latest dev version directly from GitHub can be done with
2017-10-27 15:45:38 +02:00
pip_ as well:
2015-11-03 22:08:19 +01:00
.. code:: bash
2022-03-11 02:48:10 +01:00
python3 -m pip install -U -I --no-deps --no-cache-dir https://github.com/mikf/gallery-dl/archive/master.tar.gz
2015-11-03 22:08:19 +01:00
Note: Windows users should use :code:`py -3` instead of :code:`python3`.
2017-05-09 15:43:55 +02:00
It is advised to use the latest version of pip_,
including the essential packages :code:`setuptools` and :code:`wheel`.
To ensure these packages are up-to-date, run
.. code:: bash
2022-03-11 02:48:10 +01:00
python3 -m pip install --upgrade pip setuptools wheel
2017-05-09 15:43:55 +02:00
2019-05-04 22:50:00 +02:00
Standalone Executable
---------------------
2017-05-09 15:43:55 +02:00
Prebuilt executable files with a Python interpreter and
required Python packages included are available for
2019-05-04 22:50:00 +02:00
2022-06-27 16:38:14 +02:00
- `Windows <https://github.com/mikf/gallery-dl/releases/download/v1.22.2/gallery-dl.exe>`__
- `Linux <https://github.com/mikf/gallery-dl/releases/download/v1.22.2/gallery-dl.bin>`__
2019-05-04 22:50:00 +02:00
| Executables build from the latest commit can be found at
| https://github.com/mikf/gallery-dl/actions/workflows/executables.yml
2017-06-02 09:08:08 +02:00
2017-01-25 02:31:36 +01:00
Snap
----
Linux users that are using a distro that is supported by Snapd_ can install *gallery-dl* from the Snap Store:
.. code:: bash
2022-03-11 02:48:10 +01:00
snap install gallery-dl
2017-01-24 02:36:43 +01:00
Chocolatey
----------
Windows users that have Chocolatey_ installed can install *gallery-dl* from the Chocolatey Community Packages repository:
.. code:: powershell
2022-03-11 02:48:10 +01:00
choco install gallery-dl
2019-05-04 22:50:00 +02:00
Scoop
-----
*gallery-dl* is also available in the Scoop_ "main" bucket for Windows users:
.. code:: powershell
2022-03-11 02:48:10 +01:00
scoop install gallery-dl
2015-11-03 22:08:19 +01:00
Usage
2015-11-10 21:13:43 +01:00
=====
2015-11-03 22:08:19 +01:00
2017-05-09 15:43:55 +02:00
To use *gallery-dl* simply call it with the URLs you wish to download images
2017-01-24 02:36:43 +01:00
from:
2016-11-10 16:22:59 +01:00
2015-11-03 22:08:19 +01:00
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl [OPTION]... URL...
2015-11-03 22:08:19 +01:00
2016-11-10 16:22:59 +01:00
See also :code:`gallery-dl --help`.
2017-01-24 02:36:43 +01:00
Examples
--------
2017-10-27 15:45:38 +02:00
Download images; in this case from danbooru via tag search for 'bonocho':
2017-01-24 02:36:43 +01:00
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl "https://danbooru.donmai.us/posts?tags=bonocho"
2017-01-24 02:36:43 +01:00
Get the direct URL of an image from a site supporting authentication with username & password:
2017-01-24 02:36:43 +01:00
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl -g -u "<username>" -p "<password>" "https://twitter.com/i/web/status/604341487988576256"
2017-01-24 02:36:43 +01:00
Filter manga chapters by language and chapter number:
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl --chapter-filter "lang == 'fr' and 10 <= chapter < 20" "https://mangadex.org/title/2354/"
2017-01-24 02:36:43 +01:00
| Search a remote resource for URLs and download images from them:
| (URLs for which no extractor can be found will be silently ignored)
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl "r:https://pastebin.com/raw/FLwrCYsT"
2017-01-24 02:36:43 +01:00
2020-08-15 21:29:02 +02:00
If a site's address is nonstandard for its extractor, you can prefix the URL with the
2020-07-15 15:28:20 -04:00
extractor's name to force the use of a specific extractor:
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl "tumblr:https://sometumblrblog.example"
2020-07-15 15:28:20 -04:00
2015-11-03 22:08:19 +01:00
Configuration
2015-11-10 21:13:43 +01:00
=============
2015-11-03 22:08:19 +01:00
2017-05-09 15:43:55 +02:00
Configuration files for *gallery-dl* use a JSON-based file format.
2015-11-03 22:08:19 +01:00
| For a (more or less) complete example with options set to their default values,
see gallery-dl.conf_.
| For a configuration file example with more involved settings and options,
see gallery-dl-example.conf_.
| A list of all available configuration options and their
descriptions can be found in configuration.rst_.
|
*gallery-dl* searches for configuration files in the following places:
2015-11-03 22:08:19 +01:00
Windows:
* ``%APPDATA%\gallery-dl\config.json``
* ``%USERPROFILE%\gallery-dl\config.json``
* ``%USERPROFILE%\gallery-dl.conf``
2015-11-03 22:08:19 +01:00
(``%USERPROFILE%`` usually refers to the user's home directory,
i.e. ``C:\Users\<username>\``)
Linux, macOS, etc.:
* ``/etc/gallery-dl.conf``
* ``${XDG_CONFIG_HOME}/gallery-dl/config.json``
* ``${HOME}/.config/gallery-dl/config.json``
* ``${HOME}/.gallery-dl.conf``
2015-11-03 22:08:19 +01:00
2016-11-10 16:22:59 +01:00
Values in later configuration files will override previous ones.
2015-11-03 22:08:19 +01:00
Command line options will override all related settings in the configuration file(s),
e.g. using ``--write-metadata`` will enable writing metadata using the default values
for all ``postprocessors.metadata.*`` settings, overriding any specific settings in
configuration files.
2017-01-24 02:36:43 +01:00
2016-07-25 11:13:54 +02:00
Authentication
==============
Username & Password
-------------------
Some extractors require you to provide valid login credentials in the form of
a username & password pair. This is necessary for
``nijie``
and optional for
``aryion``,
``danbooru``,
``e621``,
``exhentai``,
``idolcomplex``,
2021-03-03 03:05:25 +01:00
``imgbb``,
``inkbunny``,
``instagram``,
``mangadex``,
2021-03-03 03:05:25 +01:00
``mangoxo``,
``pillowfort``,
``sankaku``,
``subscribestar``,
``tapas``,
``tsumino``,
and ``twitter``.
2016-07-25 11:13:54 +02:00
You can set the necessary information in your configuration file
(cf. gallery-dl.conf_)
.. code:: json
2016-07-25 11:13:54 +02:00
{
"extractor": {
"twitter": {
2016-07-25 11:13:54 +02:00
"username": "<username>",
"password": "<password>"
}
}
}
or you can provide them directly via the
:code:`-u/--username` and :code:`-p/--password` or via the
:code:`-o/--option` command-line options
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl -u <username> -p <password> URL
gallery-dl -o username=<username> -o password=<password> URL
2016-07-25 11:13:54 +02:00
Cookies
-------
For sites where login with username & password is not possible due to
CAPTCHA or similar, or has not been implemented yet, you can use the
cookies from a browser login session and input them into *gallery-dl*.
This can be done via the
`cookies <https://github.com/mikf/gallery-dl/blob/master/docs/configuration.rst#extractorcookies>`__
option in your configuration file by specifying
- | the path to a Mozilla/Netscape format cookies.txt file exported by a browser addon
| (e.g. `Get cookies.txt <https://chrome.google.com/webstore/detail/get-cookiestxt/bgaddhkoddajcdgocldbbfleckgcbcid/>`__ for Chrome,
`Export Cookies <https://addons.mozilla.org/en-US/firefox/addon/export-cookies-txt/>`__ for Firefox)
- | a list of name-value pairs gathered from your browser's web developer tools
| (in `Chrome <https://developers.google.com/web/tools/chrome-devtools/storage/cookies>`__,
in `Firefox <https://developer.mozilla.org/en-US/docs/Tools/Storage_Inspector>`__)
For example:
.. code:: json
{
"extractor": {
"instagram": {
"cookies": "$HOME/path/to/cookies.txt"
},
"patreon": {
"cookies": {
"session_id": "K1T57EKu19TR49C51CDjOJoXNQLF7VbdVOiBrC9ye0a"
}
}
}
}
You can also specify a cookies.txt file with
the :code:`--cookies` command-line option:
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl --cookies "$HOME/path/to/cookies.txt" URL
OAuth
-----
*gallery-dl* supports user authentication via OAuth_ for
``deviantart``, ``flickr``, ``reddit``, ``smugmug``, ``tumblr``,
and ``mastodon`` instances.
This is mostly optional, but grants *gallery-dl* the ability
to issue requests on your account's behalf and enables it to access resources
which would otherwise be unavailable to a public user.
To link your account to *gallery-dl*, start by invoking it with
``oauth:<sitename>`` as an argument. For example:
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl oauth:flickr
You will be sent to the site's authorization page and asked to grant read
2019-03-23 22:11:08 +01:00
access to *gallery-dl*. Authorize it and you will be shown one or more
"tokens", which should be added to your configuration file.
To authenticate with a ``mastodon`` instance, run *gallery-dl* with
``oauth:mastodon:<instance>`` as argument. For example:
.. code:: bash
2022-03-11 02:48:10 +01:00
gallery-dl oauth:mastodon:pawoo.net
gallery-dl oauth:mastodon:https://mastodon.social/
2017-01-25 02:31:36 +01:00
.. _gallery-dl.conf: https://github.com/mikf/gallery-dl/blob/master/docs/gallery-dl.conf
.. _gallery-dl-example.conf: https://github.com/mikf/gallery-dl/blob/master/docs/gallery-dl-example.conf
.. _configuration.rst: https://github.com/mikf/gallery-dl/blob/master/docs/configuration.rst
.. _Supported Sites: https://github.com/mikf/gallery-dl/blob/master/docs/supportedsites.md
.. _Formatting: https://github.com/mikf/gallery-dl/blob/master/docs/formatting.md
.. _Python: https://www.python.org/downloads/
.. _PyPI: https://pypi.org/
.. _pip: https://pip.pypa.io/en/stable/
.. _Requests: https://requests.readthedocs.io/en/master/
.. _FFmpeg: https://www.ffmpeg.org/
2021-11-29 04:36:43 +01:00
.. _yt-dlp: https://github.com/yt-dlp/yt-dlp
2019-03-12 21:13:33 +01:00
.. _youtube-dl: https://ytdl-org.github.io/youtube-dl/
.. _PySocks: https://pypi.org/project/PySocks/
.. _pyOpenSSL: https://pyopenssl.org/
2019-05-04 22:50:00 +02:00
.. _Snapd: https://docs.snapcraft.io/installing-snapd
.. _OAuth: https://en.wikipedia.org/wiki/OAuth
.. _Chocolatey: https://chocolatey.org/install
.. _Scoop: https://scoop.sh
2017-01-25 02:31:36 +01:00
.. |pypi| image:: https://img.shields.io/pypi/v/gallery-dl.svg
:target: https://pypi.org/project/gallery-dl/
2017-01-25 02:31:36 +01:00
2020-11-17 19:40:45 +01:00
.. |build| image:: https://github.com/mikf/gallery-dl/workflows/tests/badge.svg
:target: https://github.com/mikf/gallery-dl/actions
2018-01-09 15:10:40 +01:00
.. |gitter| image:: https://badges.gitter.im/gallery-dl/main.svg
:target: https://gitter.im/gallery-dl/main