Skip to main content

Unofficial JMA weather forecast API wrapper in Python

Project description

aoirint_jmapy

Unofficial JMA weather forecast API wrapper in Python

気象庁天気予報データの非公式Pythonラッパー

2022-05-27時点のAPIに対応

Install

pip3 install aoirint_jmapy

Usage

東京都 東京地方のデータを見る例

from aoirint_jmapy import JmaApi, Telops

# UserAgentに含めるため、あなたのアプリケーション名、バージョンを設定することを推奨
# UserAgentは次のようになります: MyWeatherApp 0.1.0 / aoirint_jmapy 20220527.4
# アプリケーションを一般に配布する場合、不具合等により不特定多数の端末から
# 気象庁のサーバに負荷をかけることがないように、自分でキャッシュサーバを立てること等を推奨
# jma_url以下のパスを揃えると切り替えできる
jma = JmaApi(
  jma_url='https://www.jma.go.jp',
  app_name='MyWeatherApp',
  app_version='0.1.0',
)

# 東京都
forecast = jma.forecast(area_id='130000')
print(forecast)

## 東京地方
print(forecast[0])

### 3日間予報
print(forecast[0].timeSeries[0])

### 週間予報
print(forecast[0].timeSeries[1])

### 3日間天気概況
overview_forecast = jma.overview_forecast(area_id='130000')
print(overview_forecast.text)

### 週間天気概況
overview_week = jma.overview_week(area_id='130000')
print(overview_week.text)

# WeatherCodeを対応するテキストにする(Third party contentsの項を参照)
weather_code = '101'
print(Telops[weather_code][3]) # 晴時々曇

area_idを調べる

  • ※ 単一の地点のみでいい場合、気象庁の天気予報ページから手動で選択して実際のリクエストURLから抽出する方が簡単
# エリアリスト
area = jma.area()

## センターリスト(気象台リスト)
print(area.centers)

### 北海道地方: center_id=010100
#### 宗谷地方: area_id=011000
#### 上川・留萌地方: area_id=012000
print(area.centers['010100'])

### 関東甲信地方: center_id=010300
#### 東京都: area_id=130000
#### 神奈川県: area_id=140000
print(area.centers['010300'])

Supported data url list

Third party contents

「晴」「曇後雨」などのテキストは、API中でweatherCodeという数値IDで識別されます。 この数値IDに対応するテキストはAPIから取得できず、JavaScriptコードとして埋め込まれています。 利便性のため、この辞書をダンプしたものをライブラリに同梱し、コード中から参照できるようにしています。

Update const_telops.json

https://www.jma.go.jp/bosai/forecast/を開く。 開発者ツールで以下を実行、出力をコピーして貼り付けする。

console.log(JSON.stringify(Forecast.Const.TELOPS))

Development

Environment

python3 -m venv venv
source venv/bin/activate

pip3 install -r requirements.txt

Lock dependencies

pip3 install pip-tools

pip-compile requirements.in
pip-compile requirements.test.in

Test

# Download some JMA API response for test
./get_testdata.sh

pip3 install -r requirements.test.txt

mypy aoirint_jmapy/

pytest tests/

Release

GitHub Releaseを作成するとGitHub Actionsにより自動でPyPIにリリースされる。

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aoirint_jmapy-20220527.9.tar.gz (11.0 kB view details)

Uploaded Source

Built Distribution

aoirint_jmapy-20220527.9-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file aoirint_jmapy-20220527.9.tar.gz.

File metadata

  • Download URL: aoirint_jmapy-20220527.9.tar.gz
  • Upload date:
  • Size: 11.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.13

File hashes

Hashes for aoirint_jmapy-20220527.9.tar.gz
Algorithm Hash digest
SHA256 3987ef928a3ab312bfc80619789ccea0b78bbe58e36c22bd202d1002e751e68a
MD5 5972f556094c9cdf87c7a334dff9212c
BLAKE2b-256 0990d7b8479150189913202dbe2071ade3adac123c7fb84c4229cdc82ba99c02

See more details on using hashes here.

File details

Details for the file aoirint_jmapy-20220527.9-py3-none-any.whl.

File metadata

File hashes

Hashes for aoirint_jmapy-20220527.9-py3-none-any.whl
Algorithm Hash digest
SHA256 f73ce10258a98206d7aefdac9ac94b272b104ea3cf3a852d69ccf1614a56e94d
MD5 d1f40b233f736e12c546df2128316d04
BLAKE2b-256 816fe7c9e535787e0f35268724ab2486ec3786359da66a950d97a21b6b700cb2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page