質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

840閲覧

GASを使用してOpenWeathermapのUVI値を取得できない

zenbuiri

総合スコア4

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2021/07/30 08:32

編集2021/07/30 11:37

GASを使用してOpenWeathermapのUVI値を取得できない。

発生している問題・エラーメッセージ

OpenWeathermapのjsonからUVIの値をどうしても取得できません。
実行後の結果は underfineduv と返されます。

ご教示いただけますと幸いです。
よろしくお願いします。

補足情報(FW/ツールのバージョンなど)

OpenWeathermapからjsonを取得してくると、
問題なくUVI値は取得できています。

var API_KEY = "**********"; var IS_CELSIUS = true; function requestJson(path) { var url = "http://api.openweathermap.org/data/2.5/" + path + "&lang=ja&APPID=" + API_KEY; if (IS_CELSIUS) { url += "&units=metric"; } var response = UrlFetchApp.fetch(url, {muteHttpExceptions: true}); return JSON.parse(response.getContentText()); } function getCurrent(query) { var json = requestJson("weather?q=" + query); if (json.cod == "200") { var weather = json.weather[0]; var mydate = new Date(json.sys.sunset*1000) mydate = Utilities.formatDate(mydate, 'Asia/Tokyo', 'HH:mm:ss'); return json.name + ", " + json.sys.country + " の現在の天気" + ": " + weather.description + "\n" + "Temp:" + json.main.temp + "°" + (IS_CELSIUS ? "C" : "F") + "\n" + "Feels like:" + json.main.feels_like + "\n" + "Wind Speed:" + json.wind.speed + "\n" + "Humidity:" + json.main.humidity + "%" + "\n" + "Pressure:" + json.main.pressure + "hPa" + "\n" + "Sunset:" + mydate + "\n" + "UVI:" + json.main.uvi + "\nhttp://openweathermap.org/img/w/" + weather.icon + ".png"; } else { return json.message; } }

jsonの一部

0 id 000 main "Clouds" description "曇りがち" icon "04d" pop 0.68 1 dt 1627635600 temp 28.82 feels_like 32.34 pressure 1002 humidity 70 dew_point 22.8 uvi 0.15 clouds 80 visibility 10000 wind_speed 3.21 wind_deg 172 wind_gust 2.97 weather

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

odataiki

2021/07/30 08:41

質問文の基本テンプレートにある ### 発生している問題・エラーメッセージ ### 試したこと ### 補足情報(FW/ツールのバージョンなど) を質問文に追記すると回答がより多くもらえると思います。 たとえば "どうしても取得できない" ではなく "期待する取得値は100なのに0が返ってくる、Nullが返ってくる、何も返ってこない" などなど
zenbuiri

2021/07/30 11:32

アドバイスありがとうございます。 質問文に追記したいと思います。
guest

回答1

0

ベストアンサー

こんにちは、
"weather?q="からでは、UVI値を取得できないようなので
One Call APIに"weather?q="で取得した位置情報をURLのパラメータに設定してリクエストすればUVI値を取得できるようです。
以下が参考コードになります。

GAS

1var API_KEY = "*********"; 2var IS_CELSIUS = true; 3 4function requestJson(path) { 5 var url = "http://api.openweathermap.org/data/2.5/" + path + "&lang=ja&APPID=" + API_KEY; 6 if (IS_CELSIUS) { 7 url += "&units=metric"; 8 } 9 console.log(url); 10 var response = UrlFetchApp.fetch(url, { muteHttpExceptions: true }); 11 return JSON.parse(response.getContentText()); 12} 13 14function getCurrent(query) { 15 var json = requestJson("weather?q=" + (query || "御殿場")); 16 if (json.cod == "200") { 17 18 19 var json_onecall = requestJson(`onecall?lat=${json.coord.lat}&lon=${json.coord.lon}&lang=ja&appid=${API_KEY}`); 20 console.log(`現在のuviは、${json_onecall.current.uvi}です。`); 21 22 23 var weather = json.weather[0]; 24 var mydate = new Date(json.sys.sunset * 1000); 25 mydate = Utilities.formatDate(mydate, "Asia/Tokyo", "HH:mm:ss"); 26 27 return ( 28 json.name + 29 ", " + 30 json.sys.country + 31 " の現在の天気" + 32 ": " + 33 weather.description + 34 "\n" + 35 "Temp:" + 36 json.main.temp + 37 "°" + 38 (IS_CELSIUS ? "C" : "F") + 39 "\n" + 40 "Feels like:" + 41 json.main.feels_like + 42 "\n" + 43 "Wind Speed:" + 44 json.wind.speed + 45 "\n" + 46 "Humidity:" + 47 json.main.humidity + 48 "%" + 49 "\n" + 50 "Pressure:" + 51 json.main.pressure + 52 "hPa" + 53 "\n" + 54 "Sunset:" + 55 mydate + 56 "\n" + 57 "UVI:" + 58 (json.main.uvi || json_onecall.current.uvi) + 59 "\nhttp://openweathermap.org/img/w/" + 60 weather.icon + 61 ".png" 62 ); 63 } else { 64 return json.message; 65 } 66} 67

投稿2021/07/30 20:30

fake_shibe

総合スコア806

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問