我刚刚开始使用Python包直接从经济分析局(BEA)数据API访问数据。我有两个高级抽象:Request
和Results
。 Request
对象继承自dict
并使用请求库来访问数据。
import requests
class Request(dict):
_response = None
base_url = 'http://www.bea.gov/api/data'
def __init__(self, UserID, Method, ResultFormat='JSON', **params):
required_params = {'UserID': UserID,
'Method': Method,
'ResultFormat': ResultFormat}
required_params.update(params)
super(Request, self).__init__(**required_params)
@property
def response(self):
if self._response is None:
self._response = requests.get(url=self.base_url, params=self)
return self._response
因为下载数据可能非常耗时,所以我正在缓存响应属性。我当前的实现从不刷新缓存。如果字典的任何值发生变化或被添加/删除,我想刷新缓存。想法?
答案 0 :(得分:2)
只需覆盖相关的映射方法。
class Request(dict):
...
def __setitem__(self, item, value):
self._response = None
return super(Request, self).__setitem__(item, value)
def __delitem__(self, item):
self._response = None
return super(Request, self).__delitem__(item)