此模块用于百度坐标系(bd-09)、火星坐标系(国测局坐标系、gcj02)、WGS84坐标系的相互转换,并提供中文地址到坐标的转换功能,仅使用Python标准模块,无其他依赖。
中文地址到坐标转换使用高德地图API,需要申请API KEY。
需要js版本可以移步coordtransform
# 方法说明 gcj02_to_bd09(lng, lat) # 火星坐标系->百度坐标系 bd09_to_gcj02(lng, lat) # 百度坐标系->火星坐标系 wgs84_to_gcj02(lng, lat) # WGS84坐标系->火星坐标系 gcj02_to_wgs84(lng, lat) # 火星坐标系->WGS84坐标系 bd09_to_wgs84(lng, lat) # 百度坐标系->WGS84坐标系 wgs84_to_bd09(lng, lat) # WGS84坐标系->百度坐标系 # 中文地址到火星坐标系, 需要高德地图API Key g = Geocoding('API_KEY') # 这里填写你的高德Api_Key g.geocode('北京市朝阳区朝阳公园')
# 测试(转换坐标 128.543,37.065 )
$ python coordTransform_utils.py
[128.54944656269413, 37.07113427883019] [128.5365893261212, 37.058754503281534] [128.54820547949757, 37.065651049489816] [128.53779452050244, 37.06434895051018] [128.53136876750008, 37.0580926428705] [128.55468192918485, 37.07168344938498] None# 查看使用帮助 $ python coord_converter.py -h usage: coord_converter.py [-h] -i INPUT -o OUTPUT -t TYPE [-n LNG_COLUMN] [-a LAT_COLUMN] [-s SKIP_INVALID_ROW] Convert coordinates in csv files. optional arguments: -h, --help show this help message and exit arguments: -i , --input Location of input file -o , --output Location of output file -t , --type Convert type, must be one of: g2b, b2g, w2g, g2w, b2w, w2b -n , --lng_column Column name for longitude (default: lng) -a , --lat_column Column name for latitude (default: lat) -s , --skip_invalid_row Whether to skip invalid row (default: False)
# 不指定经纬度列名(默认为'lng', 'lat') $ python coord_converter.py -i test_input.csv -o test_output.csv -t b2g # 指定经纬度列名 $ python coord_converter.py -i test_input.csv -o test_output.csv -t b2g -n 经度 -a 纬度 # 跳过无效经纬度的行(默认不跳过) $ python coord_converter.py -i test_input.csv -o test_output.csv -t b2g -n 经度 -a 纬度 -s True