A Trefle API Integration.
Project description
Shamrock - A Trefle API Library
☘ Shamrock is a Python shallow API library for Trefle integration. It enables interacting with the Trefle plants API in Python to get the information needed for various things you might want to use the API with such as research, gardening software, automation, etc. It is made for use with Python 3.6 and above.
For the full documentation refer to Shamrock documentation.
For more information what the Trefle service provides, refer to the Trefle API documentation. It is also useful for checking out how to use the API with Shamrock library.
Installation
pipenv install shamrock
or
pip install shamrock
Simple Usage Example
from shamrock import Shamrock api = Shamrock('mytoken') species = api.species()
Advanced Usage
You can configure the API initially like this:
api = Shamrock(TOKEN)
Methods that can be run with the API are:
api.kingdoms() api.subkingdoms() api.divisions() api.division_classes() api.division_orders() api.families() api.genus() api.plants() api.species()
They correspond to the Trefle API endpoints.
You can also query a specific item from the database:
api.plants(103505)
Searching is covered with a separate method:
api.search("tomato")
Navigating the API is covered with these methods:
api.next() api.prev() api.first() api.last()
It will work only if you previously made a request. For example:
api.species() api.next()
You can also use the varoius query string options described on Trefle API documentation as keyword arguments in methods, however, be careful when unpacking filters, for example:
filters = {"filter[common_name]" : "blackwood"} api.species(**filters)
History
0.0.1 (27.04.2019.)
First release on PyPI.
0.0.2 (21.07.2020.)
Trefle.io changed so this release retains links to an old version that is to be removed.
0.1.0 (22.07.2020.)
- Trefle.io updated so these things were changed:
Authorization is now handled through query parameter, copy module needed, new query_parameters property added and removed headers property.
Pagination handled through links in the body and made relative instead of absolute. No more page size.
Gzip response needed to unwrap the JSON response now. Will remove this in the future versions.
New bascic endpoints added for division classes, division orders and distributions.
Added new methods for client-side auth, selecting plants by distributions or genus, submitting errors and corrections.
Genuses endpoint renamed to genus.
Versioning of the API started so the url parameter in the constructor is split to base and relative urls.
Response changed to handle the added meta and links additions for the navigation.
Added ShamrockException wrapper for the low level library exceptions.
0.2.0 (15.07.2021.)
Trefle.io got deprecated so base_url parameter is now available when initiating Shamrock for drop-in replacements.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.