0

我正在使用 while 循环轮询 API 端点,该循环检查 JSON 上的 .get() 方法是否返回 None:

    while requests.get(render_execution_url, headers=headers).json().get('finalized_at') is None:
        status = requests.get(render_execution_url, headers=headers).json().get('status')
        status_detail = requests.get(render_execution_url, headers=headers).json().get('status_detail')
        logger.info("status for {} is {}.  detailed status is {}".format(render_execution_url, status, status_detail))

这里的想法是我们不断轮询端点,直到填充“finalized_at”值。

不幸的是,当 JSON 根本不存在时,我们会定期失败:

 File "/usr/lib/python2.7/json/__init__.py", line 339, in loads
   return _default_decoder.decode(s)
 File "/usr/lib/python2.7/json/decoder.py", line 364, in decode
   obj, end = self.raw_decode(s, idx=_w(s, 0).end())
 File "/usr/lib/python2.7/json/decoder.py", line 382, in raw_decode
   raise ValueError("No JSON object could be decoded")
ValueError: No JSON object could be decoded

我已经尝试在该方法上使用重试装饰器(有关装饰器语法,请参见下文),但是当我遇到此失败时,它似乎没有执行重试。

@retry(stop_max_attempt_number=7, wait_fixed=10000)

是否有一种优雅的 Pythonic 方式来处理 JSON 不存在的情况(即,在一段时间内再试一次)?

4

1 回答 1

2

您的代码太密集,无法轻松分离出您需要处理的不同条件,因此您的错误报告并没有明确说明“当 JSON 根本不存在时”是什么意思 - 服务器返回 404 (Page Not Found),或者响应数据是空的,还是别的什么?

这是一个重写,每次访问 JSON 时都不会访问 URL。它可能无法完全满足您的需求,但它应该让您开始。

while True:
    resp = requests.get(render_execution_url, headers=headers)
    # I assume response status is always 200 or 204 -
    # Really easy to detect a 404 here if that happens.
    if not resp.data:
        time.sleep(WAIT_TIME)
        continue
    rj = resp.json()
    if rj.get('finalized_at') is not None:
        break
    status = rj.get('status')
    status_detail = rj.get('status_detail')
    logger.info("status for {} is {}.  detailed status is {}"
                .format(render_execution_url, status, status_detail))
    time.sleep(WAIT_TIME)
于 2019-03-06T17:06:25.950 回答