c#获取中国三级行政区域划分(省市县)以及县级经纬度demo

本文介绍了如何使用C#获取中国的省市县三级行政区域划分,并通过在线方式获取县级行政区域的经纬度。内容包括定义行政区域模型、解析HTML获取数据、获取经纬度信息以及将实体序列化为JSON或XML。
摘要由CSDN通过智能技术生成

##1 定义三级model

  [XmlRoot("country")]
    public class Country
    {
        [XmlElement("provinces")]
        public List<Province> provinces { get; set; }
        [XmlAttribute]
        public string name { get; set; }
    }

   public class Province
    {
        [XmlElement("city")]
        public List<City> citys { get; set; }
        [XmlAttribute]
        public string name { get; set; }
        [XmlAttribute]
        public string code { get; set; }
    }


   public class City
    {
        [XmlElement("county")]
        public List<County> Counties { get; set; }
        [XmlAttribute]
        public string name { get; set; }
        [XmlAttribute]
        public string code { get; set; }
    }
   public class County
    {
        [XmlAttribute]
        public string name { get; set; }
        [XmlAttribute]
        public string code { get; set; }
        /// <summary>
        /// 经度
        /// </summary>
        [XmlAttribute]
    public double longitude { get; set; }
        /// <summary>
        /// 维度
        /// </summary>
        [XmlAttribute]
   public double latitude { get; set; }
    }

##2 在线获取行政区域划分 地址:http://www.stats.gov.cn/tjsj/tjbz/xzqhdm/201504/t20150415_712722.html 获取以上html代码并解析出行政区域

string url = "http://www.stats.gov.cn/tjsj/tjbz/xzqhdm/201504/t20150415_712722.html";     
string html = CoordinateHelper.HttpHelper(url);`
string str = Regex.Match(html, "<div class=\"xilan_con\".*?</div>").ToString();
MatchCollection matches = Regex.Matches(str, "<p.*?>(\\d+).*?</p>");
List<Province> list = new List<Province>();
            foreach (Match match in matches)
            {
                //<p class="MsoNormal" align="justify">110000&nbsp;&nbsp;&nbsp; 北京市</p>
                var group = match.Groups[1];
                string code = group.Value;
                string name = Regex.Replace(match.ToString(), "<.*?>", "");
                name = Regex.Replace(name, "&nbsp;", "");
                name = Regex.Replace(name, code, "");
                name = name.Trim();
                if (code.EndsWith("00"))
                {
                    var temp = list.FirstOrDefault(p => p.code.StartsWith(code.Substring(0, 2)));
                    if (temp == null)
                    {
                        Province province = new Province();
                        province.code = code;
  
从国家统计局抓取的地图省市区划代码和城划分代码(最新2020/06/03),共596071条数据。来源于国家统计局http://www.stats.gov.cn/tjsj/tjbz/tjyqhdmhcxhfdm/2019/。 数据结构: CREATE TABLE `area` ( `areaid` varchar(255) COLLATE utf8_unicode_ci NOT NULL, `area_name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, `fatherid` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL, `area_type` int(255) DEFAULT NULL COMMENT '区域代码:\r\n100 :城镇,110:城区,111 :主城区,112 :城乡结合区,120 :镇区,121 :镇中心区,122:镇乡结合区,123:特殊区域200 :乡村,210:乡中心区,220:村庄\r\n\r\n', `is_delete` int(255) DEFAULT '0', PRIMARY KEY (`areaid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; 部分数据: INSERT INTO `area` VALUES ('110000000000','北京市',NULL,NULL,0); INSERT INTO `area` VALUES ('110100000000','市辖区','110000000000',NULL,0); INSERT INTO `area` VALUES ('110101000000','东城区','110100000000',NULL,0); INSERT INTO `area` VALUES ('110101001000','东华门街道','110101000000',NULL,0); INSERT INTO `area` VALUES ('110101001001','多福巷社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001002','银闸社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001005','东厂社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001006','智德社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001007','南池子社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001008','黄图岗社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001009','灯市口社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001010','正义路社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001011','甘雨社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001013','台基厂社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001014','韶九社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101001015','王府井社区居委会','110101001000',111,0); INSERT INTO `area` VALUES ('110101002000','景山街道','110101000000',NULL,0); INSERT INTO `area` VALUES ('110101002001','隆福寺社区居委会','110101002000',111,0); INSERT INTO `area` VALUES ('110101002002','吉祥社区居
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值