1

我必须将我的 API 请求限制为每分钟 10 次调用,如何修改 for 循环来完成此操作?

我试图在没有任何运气的情况下添加time.sleep(8)到循环中......有什么想法吗?for observation

import arrow # learn more: https://python.org/pypi/arrow
from WunderWeather import weather # learn more: https://python.org/pypi/WunderWeather
import time

api_key = ''
extractor = weather.Extract(api_key)
zip = '53711'

# get 20170101 00:00
begin_date = arrow.get("2017","YYYY")
# get 20171231 23:00
end_date = arrow.get("2018","YYYY").shift(hours=-1)
for date in arrow.Arrow.range('hour',begin_date,end_date):
  # get date object for feature
  # http://wunderweather.readthedocs.io/en/latest/WunderWeather.html#WunderWeather.weather.Extract.date
  date_weather = extractor.date(zip,date.format('YYYYMMDD'))

  # use shortcut to get observations and data
  # http://wunderweather.readthedocs.io/en/latest/WunderWeather.html#WunderWeather.date.Observation
  for observation in date_weather.observations:
    time.sleep(8)
    print("Date:",observation.date_pretty)
    print("Temp:",observation.temp_f)
4

2 回答 2

0

根据您希望数据的实时性或您可以承受落后一天的负担,您可以获得过去某个日期的所有观察结果,这将是一个 API 调用来检索一天的数据(或者它可能是一天结束当天观察的总结)。

或者,如果您试图每隔 x 分钟左右(在限制以下)获取当前天气,我会使用某种带有计时器的循环(或者可能扭曲,这似乎抽象了“循环”)但打个电话到以下之一(取决于您要查找的内容)。您当前的代码正在查找过去的日期,但这些其他端点是当天的。

您不希望在观察循环中使用计时器,因为如上所述,可能没有计时器。

http://wunderweather.readthedocs.io/en/latest/WunderWeather.html#WunderWeather.weather.Extract.hourly_daycast

http://wunderweather.readthedocs.io/en/latest/WunderWeather.html#WunderWeather.weather.Extract.today_now

可以调用类似于以下示例 http://wunderweather.readthedocs.io/en/latest/index.html#additional-examples

于 2017-12-19T22:28:40.173 回答
0

为什么您仍然超过 API 限制的可能解释可能与您添加时间等待的行有关。如果您获得的 API 响应不包含任何观察结果,则内部循环将不会执行。因此,首先我会尝试在 API 调用之后立即在外部循环中移动等待时间。

您也可以考虑使用类似 loopingCall from twisted 的方法来安排您的任务每 X 秒运行一次 http://twistedmatrix.com/documents/9.0.0/core/howto/time.html

于 2017-12-18T18:35:04.473 回答