A python interface to interact with the USDA's FoodDataCentral API
- An object oritented interface for FoodDataCentral's
- Python >=3.10
The simplest way to install it is to pip install it.
pip install py-usda-fdcTo install the development version you can pip the git version.
pip install git+https://github.com/ghostiek/py-fdc.gitAn API Key is necessary to make calls to USDA's API. You can get one by filling in this form.
# Import the FDC module
from fdc.fdc import FDC
# Initialize the client with your API key
client = FDC(api_key)# Get Food using FDCId
food = client.get_food(fdc_id) # Returns a Food object
# Get multiple Foods using a list of FDCIds
foods = client.get_foods([fdc_id1, fdc_id2, fdc_id3]) # Returns a list of Food objects
# Get a paged list of foods
food_list = client.get_foods_list() # Returns a list of AbridgedFood
# Search foods using keywords, in this case, get 200 cheese items
cheeses = client.get_foods_search("cheese") # Returns a SearchResult objectUnfortunately, the USDA's FoodDataCentral API can be quite inconsistent at times, I've tried mapping it the best I could but if it results in an error, you can always just get the json string using the raw parameter Here is the equivalent of the functions referenced previously, except the output is a string.
# All of them are strings
food_raw = client.get_food_raw(fdc_id)
foods_raw = client.get_foods_raw([fdc_id1, fdc_id2, fdc_id3])
food_list_raw = client.get_foods_list_raw()
cheeses_raw = client.get_foods_search_raw("cheese")More information about the API is available here