Book vaccine slots on Doctolib
Project description
DOCTOSHOTGUN
This script lets you automatically book a vaccine slot on Doctolib in France and in Germany in the next seven days.
Python dependencies
- woob
- cloudscraper
- dateutil
- termcolor
- colorama
- playsound (optional)
How to use it
You need python3 for this script. If you don't have it, please install it first.
Install dependencies:
pip install -r requirements.txt
Run:
./doctoshotgun.py <country{fr,de}> <city> <email> [<password>]
Further optional arguments:
--debug, -d show debug information
--pfizer, -z select only Pfizer vaccine
--moderna, -m select only Moderna vaccine
--janssen, -j select only Janssen vaccine
--astrazeneca, -a select only AstraZeneca vaccine
--only-second, -2 select only second dose
--only-third, -3 select only third dose
--patient PATIENT, -p PATIENT
give patient ID
--time-window TIME_WINDOW, -t TIME_WINDOW
set how many next days the script look for slots (default = 7)
--center CENTER, -c CENTER
filter centers
--zipcode CODE
filter centers by zipcode
--center-regex CENTER_REGEX
filter centers by regex
--center-exclude CENTER_EXCLUDE, -x CENTER_EXCLUDE
exclude centers
--center-exclude-regex CENTER_EXCLUDE_REGEX
exclude centers by regex
--include-neighbor-city, -n
include neighboring cities
--start-date START_DATE
first date on which you want to book the first slot (format should be DD/MM/YYYY)
--end-date END_DATE last date on which you want to book the first slot (format should be DD/MM/YYYY)
--weekdays-exclude, -e
exclude weekdays, e.g. "tuesday Wednesday FRIDAY"
--dry-run do not really book the slot
--code CODE 2FA code
--confirm prompt to confirm before booking
With Docker
Build the image:
docker build . -t doctoshotgun
Run the container:
docker run -it doctoshotgun <country{fr,de}> <city> <email> [<password>]
Multiple cities
You can also look for slot in multiple cities at the same time. Cities must be separated by commas:
$ ./doctoshotgun.py <country{fr,de}> <city1>,<city2>,<city3> <email> [<password>]
Filter on centers
You can give name of centers in which you want specifically looking for:
$ ./doctoshotgun.py fr paris roger.philibert@gmail.com \
--center "Centre de Vaccination Covid 19 - Ville de Paris" \
--center "Centre de Vaccination du 7eme arrondissement de Paris - Gymnase Camou"
Select patient
For doctolib accounts with more thant one patient, you can select patient just after launching the script:
$ ./doctoshotgun.py fr paris roger.philibert@gmail.com PASSWORD
Available patients are:
* [0] Roger Philibert
* [1] Luce Philibert
For which patient do you want to book a slot?
You can also give the patient id as argument:
$ ./doctoshotgun.py fr paris roger.philibert@gmail.com PASSWORD -p 1
Starting to look for vaccine slots for Luce Philibert in 1 next day(s) starting today...
Set time window
By default, the script looks for slots between now and next day at 23:59:59. If you belong to a category of patients that is allowed to book a slot in a more distant future, you can expand the time window. For exemple, if you want to search in the next 5 days :
$ ./doctoshotgun.py fr paris roger.philibert@gmail.com -t 5
Password:
Starting to look for vaccine slots for Roger Philibert in 5 next day(s) starting today...
This may take a few minutes/hours, be patient!
Look on specific date
By default, the script looks for slots between now and next day at 23:59:59. If you can't be vaccinated right now (e.g covid in the last 3 months or out of town) and you are looking for an appointment in a distant future, you can pass a starting date:
$ ./doctoshotgun.py fr paris roger.philibert@gmail.com --start-date 17/06/2021
Password:
Starting to look for vaccine slots for Roger Philibert in 7 next day(s) starting 17/06/2021...
This may take a few minutes/hours, be patient!
Filter by vaccine
The Pfizer vaccine is the only vaccine allowed in France for people between 16 and 18. For this case, you can use the -z option.
$ ./doctoshotgun.py fr paris roger.philibert@gmail.com PASSWORD -z
Starting to look for vaccine slots for Luce Philibert...
Vaccines: Pfizer
This may take a few minutes/hours, be patient!
It is also possible to filter on Moderna vaccine with the -m option and Janssen with the -j option.
Development
Running tests
$ pip install -r requirements-dev.txt
$ pytest test_browser.py
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file doctoshotgun-1.0.1.tar.gz
.
File metadata
- Download URL: doctoshotgun-1.0.1.tar.gz
- Upload date:
- Size: 27.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.6.4 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ef23a3f4ad4fbbea16b732c11ef3e5eabc60ea63e8cef0afe9e21ba1a8d190d5 |
|
MD5 | 3266f09b472541c440eb9e2006d4ae3b |
|
BLAKE2b-256 | 69263283c1d887e0d5b774226c8fd9700d89a07d49faef6a69a87024081f18e7 |
File details
Details for the file doctoshotgun-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: doctoshotgun-1.0.1-py3-none-any.whl
- Upload date:
- Size: 27.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.6.4 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3307c01c1230e9239141d1697d41389d62c460454bdcff415c32c9f6a9d4a9fc |
|
MD5 | 88e32f496e39f082555f9eec1a4c9505 |
|
BLAKE2b-256 | 0f38fc011956a2d514d0508cb9220938f4a8f7aaf30f72609f6b12e34c7d64be |