如何从 Google 反向地理编码中可靠地找到邮政编码

How to reliably find postal code from Google reverse geocoding

我需要根据城市和省名获取具有代表性的加拿大邮政编码。我最初的方法是使用 Google 的地理编码 API 将城市、省份转换为 [lat,lng] 反向地理编码以获得匹配地址,并从中提取邮政编码。城市和省份来自使用 Google 地图自动完成的表格,所以我知道它们(至少几乎)总是有效的。在一些测试中,这工作正常,但我很快 运行 进入我们实际数据中失败的案例:曼尼托巴省雪湖。

https://maps.googleapis.com/maps/api/geocode/json?address=Snow+Lake%2C+Manitoba&key=MYKEY

在几何部分,我得到:

location    
    lat 54.87856679999999
    lng -100.0220321
location_type   "APPROXIMATE"

但是每当我查找那个位置(包括不同级别的精度)时,我得到的结果都不包含邮政编码。

https://maps.googleapis.com/maps/api/geocode/json?latlng=54.8785668,-100.0220321&key=MYKEY

我也尝试过从各种事物返回的 place_id,但没有成功。 St运行ge 问题是,如果我在常规 Google 地图站点中搜索 Snow Lake, Manitoba,它会精确定位并告诉我邮政编码是 R0B 1M0。那么为什么他们的网站提供了很好的信息,而不是 API?即使我将第二个 URL 中的位置替换为 Google 地图在搜索后 URL 中的位置 (54.8808471,-100.0274579),我仍然没有找回邮政编码,如果我使用它为该位置提供的地址 (531 Lakeshore Drive),我也不会。

通过反复试验(查看 Google 地图中的一些街道名称),我发现搜索 117 Balsam St. 会同时提供邮政编码和位置,我可以通过反向地理编码来获取邮政编码代码。但是我传入的数据没有街道名称或号码,只有城市和省份,所以这不是解决方案。这个地址确实为我提供了 location_type 的 ROOFTOP,而不是我为其他人获得的 APPROXIMATE 或 RANGE_INTERPOLATED。

有人知道这是怎么回事吗?有没有一种可靠的方法可以让我从这个 API 中得到我需要的东西,或者它只是一个碰碰运气的命题?

我相信使用反向地理编码搜索 postal 代码的想法通常是正确的,但在某些情况下它可能不起作用。让我举例说明。

  1. 邮政编码 QC H1H。如果您在 Google 地图中查看此 postal 代码,您将看到它具有多边形几何形状,如我的屏幕截图所示

https://www.google.com/maps/place/Montr%C3%A9al-Nord,+QC+H1H,+Canada/@45.5755194,-73.6272394,14z/data=!4m5!3m4!1s0x4cc91f6dd2d3b269:0xc3ff559c136d8af2!8m2!3d45.5893471!4d-73.6419587

因此,如果您在该多边形内指定一个点,例如 45.594402,-73.642216,并执行反向地理编码,同时指定结果类型应为 postal 代码,您将得到结果

https://maps.googleapis.com/maps/api/geocode/json?latlng=45.594402%2C-73.642216&result_type=postal_code&key=YOUR_API_KEY

  1. 您示例中的邮政编码 R0B 1M0。如果您在 Google 地图中查看此 postal 代码,您会发现此 postal 代码没有多边形几何图形。它被定义为一个点。

https://www.google.com/maps/place/Snow+Lake,+MB+R0B+1M0,+Canada/@54.8792581,-100.0226575,17.04z/data=!4m5!3m4!1s0x52f631c0d3937ca9:0x143db2e5b7611e34!8m2!3d54.880844!4d-100.0252639

由于这个原因,反向地理编码失败并且 returns ZERO_RESULTS。

https://maps.googleapis.com/maps/api/geocode/json?latlng=54.87856679999999%2C-100.0220321&result_type=postal_code&key=YOUR_API_KEY

我认为这是 Google 方面的数据问题,您可以按照 Google 地图帮助将其报告给 Google:

https://support.google.com/maps/answer/3094088

如果 postal 代码没有关联的多边形几何图形,我可以建议以下解决方法:

  • 执行地点 API 查找,使用位置和半径坐标进行查找,例如 2-5 公里,类型设置为 post 办公室

https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=54.87856679999999%2C-100.0220321&radius=2000&type=post_office&key=YOUR_API_KEY

请求 returns postal office with place ID ChIJp3yT08Ax9lIRk0eG4BkTvXg.

  • 对上述地点 ID 执行地理编码请求

https://maps.googleapis.com/maps/api/geocode/json?place_id=ChIJp3yT08Ax9lIRk0eG4BkTvXg&key=YOUR_API_KEY

从 post 办公室的地址部分提取 postal 代码

{
    "address_components":[
    {
      "long_name":"81",
      "short_name":"81",
      "types":[
        "street_number"
      ]
    },
    {
      "long_name":"Balsam Street",
      "short_name":"Balsam St",
      "types":[
        "route"
      ]
    },
    {
      "long_name":"Snow Lake",
      "short_name":"Snow Lake",
      "types":[
        "locality","political"
      ]
    },
    {
      "long_name":"Division No. 21",
      "short_name":"Division No. 21",
      "types":[
        "administrative_area_level_2","political"
      ]
    },
    {
      "long_name":"Manitoba",
      "short_name":"MB",
      "types":[
        "administrative_area_level_1","political"
      ]
    },
    {
      "long_name":"Canada",
      "short_name":"CA",
      "types":[
        "country","political"
      ]
    },
    {
      "long_name":"R0B 1M0",
      "short_name":"R0B 1M0",
      "types":[
        "postal_code"
      ]
 }

希望对您有所帮助!