为特定国家生成随机坐标

Generating Random Cordinates for Specific Country

我正在尝试为一个国家/地区生成随机坐标

我用过这个库Faker

def geo_point():
    """make random cordinates"""
    faker = factory.Faker('local_latlng', country_code = 'IN')
    coords = faker.generate()
    return (coords[1], coords[0])

但这里的问题是,它的坐标集非常有限,大约在 30-40 之间,我们至少需要 10,000 个坐标来进行测试。

我尝试了一个简单的方法

def random_geo_cordinate():
    """make random geocordinates"""
    x, y = uniform(-180,180), uniform(-90, 90)
    return (y, x)

但是只有 10-20 个特定国家/地区的坐标。

有很多参考文献我发现通过shape_files我们可以生成但是在所有这些中只有geom个参数可用。

我找到了一种方法,通过它我可以通过 Geom 列检查这些坐标是否位于该国家/地区。

但是在为一个国家/地区生成随机坐标时我仍然遗漏了一些东西。

有没有简单直接的方法

正在使用

POST GIS Database
GeoDjango Server

注:

  1. 我使用 GDAL 获取一个国家/地区的 shapefile

您可以使用 Overpass API,它查询 OSM 数据库,这样您就可以获得真实的坐标。
例如获取印度的所有村庄:

import requests
import json

overpass_url = "http://overpass-api.de/api/interpreter"
overpass_query = """
[out:json];area[name="India"];(node[place="village"](area););out;
"""

response = requests.get(
    overpass_url, 
    params={'data': overpass_query}
)

coords = []
if response.status_code == 200:
    data = response.json()
    places = data.get('elements', [])
    for place in places:
        coords.append((place['lat'], place['lon']))
     print ("Got %s village coordinates!" % len(coords))
     print (coords[0])
else:
     print("Error")

输出:

Got 102420 village coordinates!
(9.9436615, 77.8978759)

注意:立交桥API有速率限制,所以你应该在本地保存所有坐标并从那里提取你的随机集!
此外,您可以尝试仅获取城市或城镇的 places 参数,或获取特定地区的餐厅位置,...

https://3geonames.org/randomland.IN 是一个免费的 API returns 世界上任何国家/地区的随机位置。