An official website of the United States government
Accessing the Public Data API with Python
Multiple Series and Multiple YearsUse this code to retrieve data for more than one timeseries and more than one year. Sample Python Script: import requests import json import prettytable headers = {'Content-type': 'application/json'} data = json.dumps({"seriesid": ['CUUR0000SA0','SUUR0000SA0'],"startyear":"2011", "endyear":"2014"}) p = requests.post('https://api.bls.gov/publicAPI/v2/timeseries/data/', data=data, headers=headers) json_data = json.loads(p.text) for series in json_data['Results']['series']: x=prettytable.PrettyTable(["series id","year","period","value","footnotes"]) seriesId = series['seriesID'] for item in series['data']: year = item['year'] period = item['period'] value = item['value'] footnotes="" for footnote in item['footnotes']: if footnote: footnotes = footnotes + footnote['text'] + ',' if 'M01' <= period <= 'M12': x.add_row([seriesId,year,period,value,footnotes[0:-1]]) output = open("c:\\temp\\" + seriesId + ".txt","w") output.write (x.get_string()) output.close()
Acknowledgments:The BLS API Team thanks Mark McEnearney for contributing the above sample Python Script.
Last Modified Date: October 16, 2014 |