全国省市县三级行政单位JSON解析,加载到缓存。

2024-05-02 07:08

本文主要是介绍全国省市县三级行政单位JSON解析,加载到缓存。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

全国省市县三级行政单位JSON解析后加载到缓存。

一、主要实现的功能:

1、将全国JSON格式的文本文件IO读取为字符串。

2、将该字符串进行JSON解析,加载到缓存中。

3、依据省名称,可以查找到该省下的所有城市。

4、依据市名称,可以查找到该市下的所有区县。

5、依据市名称查找该市属于哪个省。

二、执行结果示例:

江苏省下辖市有:[盐城市, 徐州市, 泰州市, 南京市, 扬州市, 常州市, 镇江市, 宿迁市, 苏州市, 淮安市, 连云港市, 南通市, 无锡市]
南京市下辖区县有: [玄武区, 白下区, 秦淮区, 建邺区, 鼓楼区, 下关区, 浦口区, 栖霞区, 雨花台区, 江宁区, 六合区, 溧水县, 高淳县]
南京市属于:江苏省

三、全国省市县三级行政单位JSON格式文件。

      请到如下地址下载:http://download.csdn.net/download/tzszhzx/8402791

 

四、实现代码(需要引入fastJson.jar,并把JSON文件放到该类的包路径下):

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.net.URL;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map.Entry;import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;public class AreaManager
{//省与市的列表键值对,可依据省名,获得该省下的城市列表@SuppressWarnings("rawtypes")private static HashMap<String, ArrayList> province_city_Map = new HashMap<String, ArrayList>();//市与省的建值对,可以依据市获取该市属于哪个省。private static HashMap<String ,String> city_province_Map = new HashMap<String, String>();//城市与区县的键值对,依据城市名称可以取得该城市下的所有区县列表。@SuppressWarnings("rawtypes")private static HashMap<String, ArrayList> city_town_Map = new HashMap<String, ArrayList>();public static void main(String args[]){//读取全国省市区县三级行政单位JSON文本文件为字符串String areaStr = readAreaFile();//将字符串解析,并放到三个缓存中,省对应的市列表、市一一对应的省、市对应的区县列表loadAllArea(areaStr);//依据省名获得下属的城市列表System.out.println("江苏省下辖市有:"+getCitysByProvince("江苏省"));//依据城市名称获得下属的区县列表System.out.println("南京市下辖区县有:"+getTownsByCity("南京市"));//依据城市获得所属于的省System.out.println("南京市属于:"+getBelongProvince("南京市"));}/*** 从当前路径下读取地区JSON文件转为JSON串。* @return*/private static String readAreaFile(){URL url = AreaManager.class.getResource("");File file = new File(url.getPath() + "/area-gb.json");StringBuffer buffer = new StringBuffer(1024);BufferedReader reader = null;String tempString = null;try{reader = new BufferedReader(new FileReader(file));while (null != (tempString = reader.readLine())){buffer.append(tempString);}}catch (FileNotFoundException e){e.printStackTrace();}catch (IOException e){e.printStackTrace();}finally{if (reader != null){try{reader.close();}catch (IOException e){e.printStackTrace();}}}return buffer.toString();}/*** 将JSON串中的省、市、区三级单位加载到内存中* @param areaStr*/private static void loadAllArea(String areaStr){JSONObject obj = (JSONObject) JSON.parse(areaStr);String province = null;for (Entry<String, Object> provinceCityEntty : obj.entrySet()){//获得每一个省province = provinceCityEntty.getKey();Object cityAndTowns = provinceCityEntty.getValue();if (cityAndTowns instanceof JSONObject){ArrayList<String> cityList = new ArrayList<String>();for (Entry<String, Object> cityEntry : ((JSONObject) cityAndTowns).entrySet()){//获得该省下的每一个城市String city = cityEntry.getKey();cityList.add(city);city_province_Map.put(city, province);//将城市和省建立键值,可通过市名称获得省名称Object towns = cityEntry.getValue();if (towns instanceof JSONArray){JSONArray townArray = (JSONArray) towns;if (townArray.size() > 0){ArrayList<String> townList = new ArrayList<String>();for (Object everyTown : townArray){//取得区县的名称String town = everyTown.toString();townList.add(town);//如果以市结尾,说明规模还是可以的,则单独成为市,且也放到省里去
//                                if (town.endsWith("市"))
//                                {
//                                    ArrayList<String> townAlone = new ArrayList<String>();
//                                    townAlone.add(town);
//                                    city_town_Map.put(town, townAlone);//单独成为市
//                                    cityList.add(town);//放置到省里去,可以依据省直接获得
//                                }}city_town_Map.put(city, townList);//将该市下的所有区县进行HASH}}else{System.out.println("地区文件不合法");}}province_city_Map.put(province, cityList);//将该省下的所有市进行HASH}}}/*** 依据省名称返回该省下的所有城市列表* @param province* @return*/private static ArrayList<String> getCitysByProvince(String province){if (null != province && !province.isEmpty()){return province_city_Map.get(province);}elsereturn null;}/*** 依据城市名称获得该城市下的所有区县列表* @param city* @return*/private static ArrayList<String> getTownsByCity(String city){if (null != city && !city.isEmpty()){return city_town_Map.get(city);}elsereturn null;}/*** 依据市名获得该市所属于的省* @param city* @return*/private static String getBelongProvince(String city){if (null != city && !city.isEmpty()){return city_province_Map.get(city);}elsereturn null;}}


 

 

 

 

 

这篇关于全国省市县三级行政单位JSON解析,加载到缓存。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/953666

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

poj 1981 单位圆套最多点

题意: 给n(300)个点,用单位圆去套他们,问最多能套多少个点。 解析: 点击打开链接 直接当作单位圆套最多点的模板吧,用极脚来排序。 代码: #pragma comment(linker, "/STACK:1677721600")#include <map>#include <set>#include <cmath>#include <queue>

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

多线程解析报表

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。 Way1 join import java.time.LocalTime;public class Main {public static void main(String[] args) thro