婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python獲取全國最新省市區數據并存入表實例代碼

python獲取全國最新省市區數據并存入表實例代碼

熱門標簽:百應電話機器人總部 成都呼叫中心外呼系統哪家強 地圖標注與注銷 電梯新時達系統外呼顯示e 西青語音電銷機器人哪家好 旅游廁所地圖標注怎么弄 無錫智能外呼系統好用嗎 南昌地圖標注 宿州電話機器人哪家好

本文通過調取高德行政區劃查詢接口,獲取最新的數據信息(省、市、區、經緯度、行政級別、城市編碼、行政編碼等),并通過mysql.connector存入mysql數據庫

表結構設計如下:

CREATE TABLE `districts` (
  `districtId` int(11) NOT NULL AUTO_INCREMENT,
  `districtPid` int(11) DEFAULT NULL COMMENT '上級ID',
  `name` varchar(32) DEFAULT NULL COMMENT '行政區名稱',
  `citycode` varchar(6) DEFAULT NULL COMMENT '城市編碼',
  `adcode` varchar(6) DEFAULT NULL COMMENT '城市區域編碼',
  `lng` float(13,10) DEFAULT NULL COMMENT '經度',
  `lat` float(13,10) DEFAULT NULL COMMENT '緯度',
  `level` varchar(10) DEFAULT NULL COMMENT '行政區劃級別',
  `createTime` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
  `updateTime` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`districtId`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4

python代碼如下:(需替換成自己的數據庫地址帳號密碼、及換入自己的高德key值)

# coding = utf-8
"""
@autor: linuxdba
"""
import json
import mysql.connector
import requests
 
header = {
    'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.107 Mobile Safari/537.36'
}
 
mydb = mysql.connector.connect(host='ip.....', user='username.....', password='pwd.....', port=3306,
                               database='test')
mycursor = mydb.cursor()
 
insert_sql = "INSERT INTO `districts` ( `districtpid`,`name`, `adcode`, `lng`, `lat`, `level`) VALUES (%s,%s, %s, %s, %s, %s);"
insert_city_sql = "INSERT INTO `districts` ( `districtpid`,`name`, `citycode`,`adcode`, `lng`, `lat`, `level`) VALUES (%s, %s, %s, %s, %s, %s, %s);"
 
select_sql = 'select districtId from districts where adcode = %s'
 
 
def updatedb(sql, *args):
    try:
        mycursor.execute(sql, args)
        mydb.commit()
    except Exception as e:
        print(e)
 
 
def selectdb(sql, *args):
    mycursor.execute(sql, args)
    return mycursor
 
 
updatedb(insert_sql, 0, '中華人民共和國', '100000', '116.3683244', '39.915085', 'country')
provinces = ['北京市', '天津市', '河北省', '山西省', '內蒙古自治區', '遼寧省', '吉林省', '黑龍江省', '上海市', '江蘇省', '浙江省', '安徽省', '福建省', '江西省',
             '山東省', '河南省', '湖北省', '湖南省', '廣東省', '廣西壯族自治區', '海南省', '重慶市', '四川省', '貴州省', '云南省', '西藏自治區', '陜西省', '甘肅省',
             '青海省', '寧夏回族自治區', '新疆維吾爾自治區', '臺灣省', '香港特別行政區', '澳門特別行政區']
for i in provinces:
    code_url = 'https://restapi.amap.com/v3/config/district?key=d6efa016ea883e15a0782f939d6a805ekeywords={}subdistrict=2'.format(
        i)
    res = requests.get(code_url, headers=header)
    print(code_url)
    print(res.text)
    province = json.loads(res.text)['districts']
    adcode = province[0]['adcode']
    pname = province[0]['name']
    center = province[0]['center']
    pcitycode = province[0]['citycode']
    level = province[0]['level']
    lng = province[0]['center'].split(',')[0]
    lat = province[0]['center'].split(',')[1]
    city_list = province[0]['districts']
 
    # print(pname, pcitycode, adcode, lng, lat, level)
    updatedb(insert_sql, 1, pname, adcode, lng, lat, level)
    districtpid = selectdb(select_sql, adcode).fetchone()[0]
    # print(city_list)
    for city in city_list:
        citycode = city['citycode']
        adcode = city['adcode']
        name = city['name']
        level = city['level']
        lng = city['center'].split(',')[0]
        lat = city['center'].split(',')[1]
        district_list = city['districts']
        # print(name, citycode, adcode, lng, lat, level)
        updatedb(insert_city_sql, districtpid, name, citycode, adcode, lng, lat, level)
        citypid = selectdb(select_sql, adcode).fetchone()[0]
        for district in district_list:
            citycode = district['citycode']
            adcode = district['adcode']
            name = district['name']
            level = district['level']
            lng = district['center'].split(',')[0]
            lat = district['center'].split(',')[1]
            district_list = district['districts']
            if level in ['district']:
                updatedb(insert_city_sql, citypid, name, citycode, adcode, lng, lat, level)
            print(name, citycode, adcode, lng, lat, level)

結果如下:

表數據文件鏈接:

http://linuxdba.ltd/files/districts.sql  或者點擊這里本地下載

總結

到此這篇關于python獲取全國最新省市區數據并存入表的文章就介紹到這了,更多相關python獲取省市區數據內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解python 利用echarts畫地圖(熱力圖)(世界地圖,省市地圖,區縣地圖)
  • 使用python實現省市三級菜單效果
  • Python版中國省市經緯度

標簽:雅安 辛集 許昌 七臺河 贛州 渭南 濰坊 西安

巨人網絡通訊聲明:本文標題《python獲取全國最新省市區數據并存入表實例代碼》,本文關鍵詞  python,獲取,全國,最新,省市區,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python獲取全國最新省市區數據并存入表實例代碼》相關的同類信息!
  • 本頁收集關于python獲取全國最新省市區數據并存入表實例代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 抚顺县| 涪陵区| 泗水县| 泗水县| 海南省| 讷河市| 前郭尔| 榆林市| 山东省| 华宁县| 桐城市| 石门县| 尼玛县| 兴安县| 固镇县| 林口县| 万州区| 孟村| 登封市| 尼玛县| 宝丰县| 抚远县| 江油市| 桃江县| 城市| 昌图县| 郧西县| 左贡县| 永春县| 德格县| 通渭县| 广州市| 凤庆县| 鹿泉市| 澄江县| 泸西县| 乡城县| 虎林市| 宿迁市| 定远县| 永泰县|