記錄

history 端點可提供特定地點在指定時間範圍內的每小時空氣品質資訊,最長可達 30 天。您可以控制要傳回哪些 AQI 和相關資訊 (例如汙染物濃度和健康建議)。

您可以使用 history 端點來要求每小時空氣品質記錄,方法是傳送 HTTP POST 要求至:

https://airquality.googleapis.com/v1/history:lookup?key=YOUR_API_KEY

將要求選項加入 JSON 要求主體。要求主體包含要取得每小時空氣品質記錄的地點和時間範圍。也可能包括多種選項,控管要在回應中加入的空氣品質資訊。

每小時要求範例

一小時的要求主體

下列程式碼示範如何使用 history 方法,為一小時的記錄要求建構要求主體。在這個範例中,您會設定位置和過去的時間戳記。

curl -X POST -d '{
  "dateTime": "2023-06-26T15:01:23Z",
  "location": {
    "latitude": 37.419734,
    "longitude": -122.0827784
  }
}' \
-H 'Content-Type: application/json' \
'https://airquality.googleapis.com/v1/history:lookup?key=YOUR_API_KEY'

一小時內回覆

上述呼叫會產生下列 JSON 回應。如要進一步瞭解回應資料,請參閱回應資料

{
    "hoursInfo": [
        {
            "dateTime": "2023-06-26T15:00:00Z",
            "indexes": [
                {
                    "code": "uaqi",
                    "displayName": "Universal AQI",
                    "aqi": 73,
                    "aqiDisplay": "73",
                    "color": {
                        "red": 118,
                        "green": 202,
                        "blue": 51,
                        "alpha": 255
                    },
                    "category": "Good air quality",
                    "dominantPollutant": "pm10"
                }
            ]
        }
    ],
    "regionCode": "us"
}

時間範圍要求範例

時間範圍要求

以下程式碼示範如何為 history 建構要求主體,以傳回多項過往每小時空氣品質記錄。

您可以指定時間範圍 (代表開始和結束時間戳記),或指定目前時間的倒數時數,以要求多個記錄。

在以下範例中,由於您將頁面大小設為 2,因此系統會傳回兩個頁面,其中傳回四小時的空氣品質記錄要求,且每個頁麵包含兩小時的資料。

curl -X POST -d '{
  "hours": 4,
  "pageSize": 2,
  "pageToken":"",
  "location": {
    "latitude": 37.419734,
    "longitude": -122.0827784
  }
}' \
-H 'Content-Type: application/json' \
'https://airquality.googleapis.com/v1/history:lookup?key=YOUR_API_KEY'

只要傳送開始和結束時間戳記,即可提出類似的要求:

curl -X POST -d '{
  "period": {
      "startTime":"2023-06-15T08:00:00Z",
      "endTime":"2023-06-15T12:00:00Z"
  },
  "pageSize": 2,
  "pageToken":"",
  "location": {
    "latitude": 37.419734,
    "longitude": -122.0827784
  }
}' \
-H 'Content-Type: application/json' \
'https://airquality.googleapis.com/v1/history:lookup?key=YOUR_API_KEY'

時間範圍回應

上述呼叫會產生下方表單的 JSON 回應。如要進一步瞭解回應資料,請參閱回應資料

上述兩通電話都會要求四小時的空氣品質資料。不過,由於您在要求中將 pageSize 屬性設為 2,因此回應只會包含最近兩小時的結果。

{
    "hoursInfo": [
        {
            "dateTime": "2023-06-15T11:00:00Z",
            "indexes": [
                {
                    "code": "uaqi",
                    "displayName": "Universal AQI",
                    "aqi": 83,
                    "aqiDisplay": "83",
                    "color": {
                        "red": 74,
                        "green": 185,
                        "blue": 54,
                        "alpha": 255
                    },
                    "category": "Excellent air quality",
                    "dominantPollutant": "o3"
                }
            ]
        },
        {
            "dateTime": "2023-06-15T10:00:00Z",
            "indexes": [
                {
                    "code": "uaqi",
                    "displayName": "Universal AQI",
                    "aqi": 89,
                    "aqiDisplay": "89",
                    "color": {
                        "red": 48,
                        "green": 175,
                        "blue": 55,
                        "alpha": 255
                    },
                    "category": "Excellent air quality",
                    "dominantPollutant": "o3"
                }
            ]
        }
    ],
    "regionCode": "us",
    "nextPageToken": "ChYaEgl3gv3XubVCQBEsNMY9TTdUMTE6MDA6MDA"
}

請注意,回應也會包含 nextPageToken 屬性。請使用此屬性存取結果的下一頁,其中含有接下來兩小時的資料。

如要存取下一頁的結果,請對 history 端點發出第二個要求,但這次將 pageToken 屬性設為第一個回應中的 nextPageToken 值。

curl -X POST -d '{
  "hours": 4,
  "pageSize": 2,
  "pageToken":"ChYaEgl3gv3XubVCQBEsNMY9TTdUMTE6MDA6MDA",
  "location": {
    "latitude": 37.419734,
    "longitude": -122.0827784
  }
}' \
-H 'Content-Type: application/json' \
'https://airquality.googleapis.com/v1/history:lookup?key=YOUR_API_KEY'