shot-scraper¶
shot-scraper is a tool to automate the process of updating screenshots.
Installation¶
$ python -m pip install shot-scraper
$ shot-scraper install
Note
The second line installs the required browser.
Use¶
shot-scraper can be used in two ways
…for single screenshots on the command line:
$ shot-scraper https://jupyter-tutorial.readthedocs.io/de/latest/clean-prep/index.html -o ~/Downloads/clean-prep.png
…or with additional options, e.g. for JavaScript and CSS selectors:
$ shot-scraper https://jupyter-tutorial.readthedocs.io/de/latest/clean-prep/index.html -s '#overview' -o ~/Downloads/clean-prep.png
…for a set of screenshots configured in a YAML file:
- url: https://jupyter-tutorial.readthedocs.io/de/latest/clean-prep/index.html output: ~/Downloads/clean-prep.png - url: https://www.example.org/ width: 736 quality: 40 output: example.jpg
Afterwards
shot-scraper multi
can be used, for example:$ shot-scraper multi shots.yaml Screenshot of 'https://jupyter-tutorial.readthedocs.io/de/latest/clean-prep/index.html' written to '~(Downloads/clean-prep.png' Screenshot of 'https://www.example.org/' written to 'example.jpg'
See also
In the README.md file you will find a complete overview of the possible options.
In the shot-scraper-demo repository you will find a much more comprehensive shots.yaml file.
GitHub Actions¶
shot-scraper can be easily integrated into GitHub Actions. The shot-scraper-demo repository also contains an exemplary shots.yml. Once a day, two screenshots are created and transferred back to the repository. Note, however, that saving image files that change frequently can make the revision history very unreadable. Therefore, you should use shot-scraper with caution together with GitHub Actions.