/jp-postal-code-api

無料で商用にも使える日本の郵便番号API

Primary LanguagePHPMIT LicenseMIT

日本の郵便番号API

codecov

日本の郵便番号から住所のデータを取得できるWeb APIです。

GitHub Pagesを使用して静的なJSONファイルとして配信しているため、可用性が高いのが特徴です。また、オープンソースなのでクライアントワークでも安心してご使用いただけます。もしリポジトリの永続性や GitHub Pagesの利用制限 が心配な場合は、ご自由にフォークしてご利用ください。

日本郵便によって公開されているデータ を元に住所データのJSONファイルを生成して配信しています。配信データはGitHub Actionsを使用して 毎日最新の内容に更新しています

Note

このプロジェクトの実装は madefor/postal-code-api にインスピレーションを受けています。長期間メンテナンスが行われていない同プロジェクトに代わるものとして、モダンPHPで再実装しました。オリジナルのソースコードに最大の敬意を表します。

デモ

https://jp-postal-code-api.ttskch.com

エンドポイント

https://jp-postal-code-api.ttskch.com/api/v1/{郵便番号}.json

使い方

例えば、郵便番号が 100-0014 の住所(東京都千代田区永田町)を取得したい場合は、エンドポイントのURLとレスポンスの内容は以下のようになります。

https://jp-postal-code-api.ttskch.com/api/v1/1000014.json

{
    "postalCode": "1000014",
    "addresses": [
        {
            "prefectureCode": "13",
            "ja": {
                "prefecture": "東京都",
                "address1": "千代田区",
                "address2": "永田町",
                "address3": "",
                "address4": ""
            },
            "kana": {
                "prefecture": "トウキョウト",
                "address1": "チヨダク",
                "address2": "ナガタチョウ",
                "address3": "",
                "address4": ""
            },
            "en": {
                "prefecture": "Tokyo",
                "address1": "Chiyoda-ku",
                "address2": "Nagatacho ",
                "address3": "",
                "address4": ""
            }
        }
    ]
}

1つの郵便番号に複数の住所がある場合は、レスポンスの内容は以下のようになります。

https://jp-postal-code-api.ttskch.com/api/v1/6180000.json

{
    "postalCode": "6180000",
    "addresses": [
        {
            "prefectureCode": "26",
            "ja": {
                "prefecture": "京都府",
                "address1": "乙訓郡大山崎町",
                "address2": "",
                "address3": "",
                "address4": ""
            },
            "kana": {
                "prefecture": "キョウトフ",
                "address1": "オトクニグンオオヤマザキチョウ",
                "address2": "",
                "address3": "",
                "address4": ""
            },
            "en": {
                "prefecture": "Kyoto",
                "address1": "Oyamazaki-cho, Otokuni-gun",
                "address2": "",
                "address3": "",
                "address4": ""
            }
        },
        {
            "prefectureCode": "27",
            "ja": {
                "prefecture": "大阪府",
                "address1": "三島郡島本町",
                "address2": "",
                "address3": "",
                "address4": ""
            },
            "kana": {
                "prefecture": "オオサカフ",
                "address1": "ミシマグンシマモトチョウ",
                "address2": "",
                "address3": "",
                "address4": ""
            },
            "en": {
                "prefecture": "Osaka",
                "address1": "Shimamoto-cho, Mishima-gun",
                "address2": "",
                "address3": "",
                "address4": ""
            }
        }
    ]
}

大口事業所個別番号では、事業所名以外のカナ表記と英語表記は空になります。

https://jp-postal-code-api.ttskch.com/api/v1/1008111.json

{
    "postalCode": "1008111",
    "addresses": [
        {
            "prefectureCode": "13",
            "ja": {
                "prefecture": "東京都",
                "address1": "千代田区",
                "address2": "千代田",
                "address3": "1−1",
                "address4": "宮内庁"
            },
            "kana": {
                "prefecture": "",
                "address1": "",
                "address2": "",
                "address3": "",
                "address4": "クナイチヨウ"
            },
            "en": {
                "prefecture": "",
                "address1": "",
                "address2": "",
                "address3": "",
                "address4": ""
            }
        }
    ]
}

2024年1月1日に市町村変更があった住所 を取得すると、2024年5月現在では英語表記は出力されません。元データ が更新されると、このWeb APIの配信データも最大1日の誤差で自動的に更新されます。

https://jp-postal-code-api.ttskch.com/api/v1/4328003.json

{
    "postalCode": "4328003",
    "addresses": [
        {
            "prefectureCode": "22",
            "ja": {
                "prefecture": "静岡県",
                "address1": "浜松市**区",
                "address2": "和地山",
                "address3": "",
                "address4": ""
            },
            "kana": {
                "prefecture": "シズオカケン",
                "address1": "ハママツシチュウオウク",
                "address2": "ワジヤマ",
                "address3": "",
                "address4": ""
            },
            "en": {
                "prefecture": "",
                "address1": "",
                "address2": "",
                "address3": "",
                "address4": ""
            }
        }
    ]
}

配信データの仕様

Web APIの配信データは 日本郵便によって公開されているデータ を元に生成しています。具体的なスキーマは 使い方 の例をご参照ください。 日本語表記・カナ表記・英語表記の住所データが含まれていますが、後述の制限事項があります。

制限事項

  • 大口事業所個別番号の住所データは以下のように出力されます(元データ の内容がそうであるため)
    • カナ表記は事業所名についてのみ出力されます
    • 事業所名のカナ表記は促音・拗音が大書きで出力されます
    • 英語表記は出力されません
  • 一部の住所において、英語表記のうち主に address2 フィールドの内容が途切れている場合があります(元データ の内容が そうである ため)
  • 直近1年程度以内に 市町村変更があった住所 については、英語表記は出力されません(元データが年1回程度しか更新されない ため)

自動更新

こちらのGitHub Actions Workflow によって、毎日午前0時頃に自動的に Web APIの配信データの内容を最新化しています。更新処理の具体的な内容は以下のとおりです。

  1. 日本郵便のWebサイト から 住所の郵便番号住所の郵便番号(ローマ字)事業所の個別郵便番号 のデータをダウンロード
  2. ダウンロードしたZipファイルからCSVファイルを取得
  3. CSVファイルをパースし、配信データとしてのJSONファイル群を生成
  4. その際、「住所の郵便番号」と「住所の郵便番号(ローマ字)」のデータを、日本語表記の住所が一致している場合にのみマージ
  5. 生成したJSONファイル群をコミットし、GitHub Pagesを更新

GitHub Pagesの利用制限について

2024年5月現在、GitHub Pagesで公開したサイトには 月当たり100GBの帯域制限 があります。このWeb APIの配信データの容量は平均およそ400バイトなので、毎秒104リクエスト程度のペースが1ヶ月間継続すると制限の対象となる可能性があります。

もしこの制限が心配な場合は、本リポジトリをフォークしてご自身のGitHubアカウントでホストしてご利用ください。その場合、エンドポイントのURLは

https://{あなたのGitHubユーザー名}.github.io/jp-postal-code-api/api/v1/{郵便番号}.json

のようになります。

ただし、それでも悪意ある攻撃者によって大量のリクエストが行われると利用制限の対象になる可能性があります。どうしても心配な場合は、フォークしたリポジトリを Cloudflare Pages などの多機能なホスティングサービスやその他PaaSなどに接続して、BASIC認証などをかけた状態でWeb APIをホストするといった運用を検討してください。

ローカル環境での使用

# インストール
$ git clone git@github.com:ttskch/jp-postal-code-api.git
$ cd jp-postal-code-api
$ composer install
# docs/api/v1/ 配下にJSONファイルを生成(15万ファイルほど生成されるので要注意)
$ bin/console build

貢献

  • バグの報告や機能の提案は Issue または Pull Request にてお願いします
  • Starを付けていただけると開発者のモチベーションが上がります

ライセンス

MIT

Note

日本郵便株式会社は、郵便番号データ郵便番号データ(ローマ字)、および 大口事業所個別番号データ について著作権を主張していません。