This is just a collection of utilities for python-requests, but don't really belong in requests
proper. The minimum tested requests version is 2.1.0
. In reality, the toolbelt should work with 2.0.1
as well, but some idiosyncracies prevent effective or sane testing on that version.
pip install requests-toolbelt
to get started!
The main attraction is a streaming multipart form-data object, MultipartEncoder
. Its API looks like this:
You can also use multipart/form-data
encoding for requests that don't require files:
Or, you can just create the string and examine the data:
You can easily construct a requests-style User-Agent
string:
from requests_toolbelt import user_agent
headers = {
'User-Agent': user_agent('my_package', '0.0.1')
}
r = requests.get('https://api.github.com/users', headers=headers)
The SSLAdapter
was originally published on Cory Benfield's blog. This adapter allows the user to choose one of the SSL protocols made available in Python's ssl
module for outgoing HTTPS connections:
The ForgetfulCookieJar
prevents a particular requests session from storing cookies:
On Python 3.3.0 and 3.3.1, the standard library's http
module will fail when passing an instance of the MultipartEncoder
. This is fixed in later minor releases of Python 3.3. Please consider upgrading to a later minor version or Python 3.4. There is absolutely nothing this library can do to work around that bug.
Please read the suggested workflow for contributing to this project.
Please report any bugs on the issue tracker