top of page
執筆者の写真WeatherDataScience

世界の気象観測データGSODを使ってみる

更新日:2022年10月5日

世界の気象観測データを探す


データ分析で世界の気象観測データを使いたいことがあり,探してみたというお話です.



世界の気象観測データといえば,SYNOP(地上実況気象通報式)やMETAR(定時飛行場実況気象通報式)があります.これらはオープンデータとして利用でき,中には10年以上前のデータまで公開しているWEBサイトもあります.

(e.g. OGIMET)


ただ利用するにはちょっと不便な点があって,電文形式で公開していることが多いんですよね.例えばこんな感じ.


[SYNOP]
202007080300 AAXX 08034 47662 41/70 71709 10253 20218 30009 40036
     53008 78082 8327/==
 
[METAR] 
RJTT 080300Z 21019KT 9999 -RA FEW015 SCT050 BKN100 27/21 Q1003
     TEMPO 22024G34KT=

私は航空気象に親しんでいるのでMETARは読めますが,SYNOPはほとんど暗号みたいなもので,人がそらで読むもんじゃないです.それにデータ分析で活用するには,CSV形式などテーブルデータとして整理されたものが欲しいですよね.


実は日本の気象庁WEBサイトはしっかりしていて,日本国内のデータであればCSVダウンロードできます.また海外のデータは過去3年分程度しかありませんが,入手可能です.



今回3年以上前の世界の気象観測データが必要で,NOAA(アメリカ海洋大気庁)のデータベースを中心に調べていたところ,ちょうど良いデータを見つけたのでご紹介します.それがGSODです.



GSODデータについて


GSOD (Global Surface Summary of the Day) とは,世界の気象観測データについて,時間単位のデータをNOAAが独自に日単位データとして集計したものです.具体的な要素としては,最高気温と最低気温,日平均の気温・露点温度・気圧・風などがあります.


観測地点によっては数十年以上の蓄積があり,日単位のデータ分析に使うのであれば,ても有益なデータです.

ただ注意点しなければならないのが、1日の定義が世界標準時(GMT)で00:00〜23:59となっていることです!そうするとローカルタイムとの日時のズレを気にしないといけません.


例えばアメリカ・カリフォルニア州ならば,現地時間とGMTとの差は,サマータイムも考慮するとGMT-7:00 〜 GMT-8:00 となります.

あるT日0:00〜23:59(GMT)の日単位集計は,ローカルタイムにするとGMT-7:00の場合は T-1日17:00〜T日16:59,GMT-8:00の場合は T-1日16:00〜T日15:59 となります.


ここで最高・最低気温を考えると,一般には最高気温は14時ごろ,最低気温は6時ごろに出ます.そうするとGSODデータの集計方法でも,実際の現地時間におけるT日の最高・最低気温は多くの場合正しく集計されていることが期待できます.


このようにローカルタイムとGMTとの差を意識しながら利用する必要があり,完璧ではありませんが,ある程度有用なデータとして使うことができそうです.



GSODデータをダウンロードする


では早速データを入手してみましょう.GSODサイト内を探索していくと,CSVファイルでダウンロードできるところが見つかりました.年ごとにディレクトリが分かれています.とりあえず2019年を見てみます.


すると…なにこれ?って感じですね….なんだかよくわからない数字11桁がファイル名となったCSVファイルがズラ〜っと並んでいます.数字は,少なくとも最初の5桁はWMO(世界気象機関)の国際地点番号だと思うんですが,残り6桁がよくわからない.


とりあえず 47662 を検索してみます.検索すると 47662099999.csv というファイル1つだけが引っ掛かります.これは大手町の気象庁本庁の地点番号で,実際にファイルを開いてみると TOKYO という文字が見られます.

このデータをダウンロードしてExcel等で開いてみると,なんだか気温の値が変ですね.1月なのに気温が45度って…これ華氏ですね(笑).他にも露点温度はあるけど湿度がなく,例えば不快指数などを計算するには一手間必要になってきます.


ということで,このデータを使うにはまずデータが欲しい地点の国際地点番号を探す必要があり,仮にそれが見つかっても単位の変換とか要素の変換とかが必要で,有益なんだけど使い勝手が悪い,そんなデータです.


これは大変だ….そう思っていたら,何と偶然!GSODへのアクセスと取り扱いを簡単にするRパッケージを見つけてしまいました!



R package : GSODR


GSODについて検索してて偶然,たまたま見つけたRパッケージ,GSODRを紹介します.これを使うと簡単にGSODを入手して利用することができます.また気温の単位は自動で華氏から摂氏に変換されており,露点温度から湿度も計算されているのでとても便利です.


使い方は本家サイトにまとめられていますが,やはり気象特有の国際地点番号を検索するところなど,慣れないとややこしいところもあります.以下で簡単にご紹介いたします.

まずはパッケージのインストールと呼び出しからです.


# Install and import
install.packages("GSODR")
library(GSODR)

GSODRパッケージでは地点リストも提供してくれます.ここからデータが欲しい地点の国際地点番号を検索する必要があります.ここではアメリカ・カリフォルニア州を例にとってご紹介します.


# See locations list of US, CA
load(system.file("extdata", "isd_history.rda", package = "GSODR"))
US_locatoin <- subset(isd_history, CTRY == "US")
CA_location <- subset(US_locatoin, STATE == "CA")
print( dim(CA_location) )
print( head(CA_location) )

実行すると、カリフォルニアだけでも454地点もあることがわかります!


ここからさらに地点を絞ります.NAME が都市名っぽいので,試しにサンフランシスコを検索してみます.


# See locations of "SAN FRANCISCO" within its NAME
print( subset(CA_location, grepl("SAN FRANCISCO", NAME)) )

実行してみると、SAN FRANCISCOだけでも6件ヒットしました.


次に見たいのは,観測データが存在する期間を表す BEGIN と END です.欲しいデータの期間を含む場所を選びます.2行目と6行目の地点は古いデータしかないようなので,それ以外から1つ選んでみます.1行目はサンフランシスコ国際空港ですが、STNID の最初の5桁 72494 はWMO国際地点番号だし,アメリカでは空港での観測が地方の気象観測として重要に機能していると聞いたことがあるので,ここを選ぶのが良さそうに思います(個人の主観がだいぶ入ってますが).


ではサンフランシスコ国際空港のGSODデータを実際に入手してみましょう.


# Use get_GSOD function
# Arguments
#   years : the year you want to get data
#   station : STNID of the location you want to get data
data <- get_GSOD(years = 2011:2016, station = "724940-23234")
print( head(data) )

入手したデータの各カラムの説明については,本家サイトの下の方に説明がありますのでご参照下さい.


カラムのうち STNID 〜 END は地点情報なので,不要でしょう.また 要素名_ATTRIBUTES も品質管理情報みたいなものなので,使わなくて良いと思います.


気象要素としては,TEMP(平均気温),DEWP(露点温度),MAX(最高気温),MIN(最低気温),RH(平均湿度) あたりが使える要素かなと思います.先に述べた通り,気温の単位は摂氏,また湿度はパッケージが自動で計算してくれています.


なおデータの取得方法として,緯度経度を指定して最寄りのデータを取得する,という方法もあるようです.本家サイトに例が載っていますので,ご参照下さい.


これで世界の気象観測データGSODを使えるようになりました.

閲覧数:2,272回0件のコメント

最新記事

すべて表示

Comments


bottom of page