記入日:2023-03-08 編集日:2023-03-08
SQL見るだけクエリ。今回は、天気予報のデータをAPIで取得してみます。天気予報API:Open-Meteoの続きです。取得するデータを少し間引いてみようと思います。
この記事を読むと(約5分)
APIで天気予報のデータを取得し、表示する方法がイメージできます。また、必要な時間帯のデータだけを表示する方法もイメージできます。
前回同様、Open-Meteoは、非商用利用であれば無料で使えるオープンソースの天気予報APIです。 APIキーは不要で、すぐに利用できます。世界中の場所に対して、時間ごとの7日間の天気予報を提供しています。
東京の、湿度と風速を取得してみます。
// 緯度、経度、天気変数の変数を定義する $lat = 35.6895; $lon = 139.6917; $vars = "relativehumidity_2m,windspeed_10m"; $zone = "Asia%2FTokyo"; // Open-Meteo APIのURLとパラメータを作成する $url = "https://api.open-meteo.com/v1/forecast?latitude=$lat&longitude=$lon&hourly=$vars&timezone=$zone"; // URLからJSONデータを取得 $json = file_get_contents($url); // JSONデータを連想配列に変換 $data = json_decode($json, true);
表示テーブルを整形する際に関して、
前回は、APIで取得した全ての時間帯の表示ループにしましたが。
// 配列の値を表のセルとして出力する
for ($i = 0; $i < count($hourly["time"]); $i++) {
echo "";
foreach ($hourly as $key => $value) {
echo "".$value[$i]." ";
}
echo " ";
}
今回は下記の様に、表示する時間帯を4つの時間に絞って、ループさせました。
// 配列の値を表のセルとして出力する
for ($i = 0; $i < count($hourly["time"]); $i++) {
// $key[0]の$valueの値から最初の11文字と最後の3文字を取り除く
$hour = substr($hourly["time"][$i], 11, 2);
// $hourが00か06か12か18なら
if ($hour == "00" || $hour == "06" || $hour == "12" || $hour == "18") {
echo "";
foreach ($hourly as $key => $value) {
echo "".$value[$i]." ";
}
echo " ";
}
}
東京の0時・6時・12時・18時の湿度と風速(1週間)
| time | relativehumidity_2m | windspeed_10m |
|---|---|---|
| 2026-02-26T00:00 | 92 | 8.6 |
| 2026-02-26T06:00 | 80 | 9 |
| 2026-02-26T12:00 | 75 | 9 |
| 2026-02-26T18:00 | 77 | 7.6 |
| 2026-02-27T00:00 | 85 | 6.9 |
| 2026-02-27T06:00 | 89 | 5.9 |
| 2026-02-27T12:00 | 73 | 4.5 |
| 2026-02-27T18:00 | 81 | 3.1 |
| 2026-02-28T00:00 | 97 | 1.8 |
| 2026-02-28T06:00 | 97 | 2.9 |
| 2026-02-28T12:00 | 69 | 5.6 |
| 2026-02-28T18:00 | 54 | 9.4 |
| 2026-03-01T00:00 | 60 | 8.7 |
| 2026-03-01T06:00 | 57 | 3.1 |
| 2026-03-01T12:00 | 25 | 8.9 |
| 2026-03-01T18:00 | 43 | 4.2 |
| 2026-03-02T00:00 | 69 | 2.8 |
| 2026-03-02T06:00 | 77 | 3.2 |
| 2026-03-02T12:00 | 33 | 3.1 |
| 2026-03-02T18:00 | 40 | 3.9 |
| 2026-03-03T00:00 | 72 | 3.6 |
| 2026-03-03T06:00 | 81 | 5.6 |
| 2026-03-03T12:00 | 76 | 9.9 |
| 2026-03-03T18:00 | 79 | 9.2 |
| 2026-03-04T00:00 | 89 | 8.3 |
| 2026-03-04T06:00 | 91 | 10.5 |
| 2026-03-04T12:00 | 88 | 12.8 |
| 2026-03-04T18:00 | 88 | 11.9 |
正午のみの表示だと以下の様になります。
// 配列の値を表のセルとして出力する
for ($i = 0; $i < count($hourly["time"]); $i++) {
// $key[0]の$valueの値から最初の11文字と最後の3文字を取り除く
$hour = substr($hourly["time"][$i], 11, 2);
// $hourが12なら
if ($hour == "12") {
echo "";
foreach ($hourly as $key => $value) {
echo "".$value[$i]." ";
}
echo " ";
}
}
東京の正午の湿度と風速(1週間)
| time | relativehumidity_2m | windspeed_10m |
|---|---|---|
| 2026-02-26T12:00 | 75 | 9 |
| 2026-02-27T12:00 | 73 | 4.5 |
| 2026-02-28T12:00 | 69 | 5.6 |
| 2026-03-01T12:00 | 25 | 8.9 |
| 2026-03-02T12:00 | 33 | 3.1 |
| 2026-03-03T12:00 | 76 | 9.9 |
| 2026-03-04T12:00 | 88 | 12.8 |
SQLの使いどころ
サイトに大量の情報を掲載することは、ユーザーにとってとても便利なことです。しかし、情報が多すぎると、目的の情報を見つけるのが困難になります。そのため、SQLを使用することで、情報を効率的に管理することができます。
SQLを使用することで、データベース内の情報を検索したり、フィルタリングしたりすることができます。これにより、ユーザーは目的の情報をスムーズかつ簡単に見つけることができます。
また、SQLを使用することで、データを集計したり、統合したりすることもできます。これにより、ユーザーはさまざまな視点から情報を分析することができます。つまり、サイトに多くの情報を掲載することが重要である一方で、その情報を効率的かつ簡単に管理することが求められる場合には、SQLが不可欠であるといえます。
KK
機械工学を専攻。工業デザイナーとして、国内及び海外の自動車・搬送ラインの設計などに従事した後、2003年にウェブシステム会社を設立。UI設計やウェブシステムの開発、DX化のディレクションなどを行っています。