如何根据地址获取对应的社区

2024-06-20 15:44
文章标签 地址 社区 获取 对应

本文主要是介绍如何根据地址获取对应的社区,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如何根据地址信息定位到所属社区,如果是地址中包含社区描述,可以通过正则匹配等方法提取社区信息,对于一些没有社区描述的地址,如何获取社区信息呢?本文通过addresstool工具包,通过Java实现非标准地址获取社区信息。

准备工作:
1.整理一份标准地址,包含5级行政区以及小区、道路、门牌号信息,做好分词并加载到AddressTool。
2.下载addresstool

https://gitee.com/addresstool/address

上代码

import org.address.AddressTool;
import org.address.DataTable;
import org.address.license.License;import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;public class AddressToolTest {public static void main(String[] args) throws Exception {License ls = new License();System.out.println(ls);AddressTool ss = new AddressTool();DataTable data = new DataTable();// 汉东省京州市天山区华山街道孽海社区卧龙大道元气森林香溪谷HashMap<String,String> mp1 = new HashMap<>();mp1.put("id","11111");mp1.put("province","汉东省");mp1.put("city","京州市");mp1.put("county","天山区");mp1.put("town","华山街道");mp1.put("community","孽海社区");mp1.put("road","卧龙大道");mp1.put("near_roads","天地大道中路");  // 道路别名mp1.put("road_no","1");mp1.put("aoi","元气森林香溪谷");mp1.put("other_name","香溪谷#溪谷小区");// 小区别名data.addAddressDic(mp1);HashMap<String,String> mp2 = new HashMap<>();mp2.put("id","22222");mp2.put("province","汉东省");mp2.put("city","京州市");mp2.put("county","天山区");mp2.put("town","华山街道");mp2.put("community","孽海社区");mp2.put("road","卧龙大道");mp2.put("road_no","1");mp2.put("aoi","元气森林卧龙居");mp1.put("other_name","卧龙居#龙居小区");data.addAddressDic(mp2);System.out.println("用户地址 读取完毕!!! ");// 补全行3级政区 对于行政完整的地址无需此操作
//        data.completion();
//        // 标准地址库修复,比如用户只有户室级地址,此方法为用户补充楼栋级和aoi级地址,当然,如果用户有自己已经标准化好的地址库,可以省略此方法
//        data.addressFix();data.initData(ss);//        as.close();SimpleDateFormat formatter= new SimpleDateFormat("yyyy-MM-dd 'at' HH:mm:ss z");Date date1 = new Date(System.currentTimeMillis());System.out.print(formatter.format(date1));System.out.print("   ");System.out.println("用户地址 初始化完毕!!! ");System.out.println(ss.getStdAddress("汉东省京州市天山区华山街道孽海社区卧龙大道元气森林香溪谷"));System.out.println(ss.getStdAddress("卧龙大道元气森林香溪谷"));System.out.println(ss.getStdAddress("元气森林香溪谷"));System.out.println(ss.getStdAddress("汉东省京州市天山区华山街道孽海社区卧龙大道1号"));System.out.println(ss.getStdAddress("香溪谷"));System.out.println(ss.getStdAddress("卧龙居小区"));System.out.println(ss.getStdAddress("汉东省京州市天山区华山街道孽海社区燊海香溪谷"));Date date = new Date(System.currentTimeMillis());System.out.println(formatter.format(date));for(int i=0;i<500;i++){ss.getStdAddress("汉东省京州市天山区华山街道孽海社区卧龙大道元气森林香溪谷");}date = new Date(System.currentTimeMillis());System.out.println(formatter.format(date));
//        as.close();}}

结果输出

{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林香溪谷, town=高峰街道, city=京州市, county=天山区, community=孽海社区, type=aoi, aoi_id=11111, province=汉东省, road=卧龙大道, road_no=1, aoi=元气森林香溪谷, id=11111}], addressLevel=aoi}
{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林香溪谷, town=高峰街道, city=京州市, county=天山区, community=孽海社区, type=aoi, aoi_id=11111, province=汉东省, road=卧龙大道, road_no=1, aoi=元气森林香溪谷, id=11111}], addressLevel=aoi}
{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林香溪谷, town=高峰街道, city=京州市, county=天山区, community=孽海社区, type=aoi, aoi_id=11111, province=汉东省, road=卧龙大道, road_no=1, aoi=元气森林香溪谷, id=11111}], addressLevel=aoi}
{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林香溪谷, town=高峰街道, city=京州市, county=天山区, community=孽海社区, type=aoi, aoi_id=11111, province=汉东省, road=卧龙大道, road_no=1, aoi=元气森林香溪谷, id=11111}, {address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林卧龙居, province=汉东省, town=高峰街道, city=京州市, road=卧龙大道, road_no=1, county=天山区, aoi=元气森林卧龙居, id=22222, community=孽海社区, type=aoi, aoi_id=22222}], addressLevel=road_no}
{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林香溪谷, town=高峰街道, city=京州市, county=天山区, community=孽海社区, type=aoi, aoi_id=11111, province=汉东省, road=卧龙大道, road_no=1, aoi=元气森林香溪谷, id=11111}], addressLevel=aoi}
{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林卧龙居, province=汉东省, town=高峰街道, city=京州市, road=卧龙大道, road_no=1, county=天山区, aoi=元气森林卧龙居, id=22222, community=孽海社区, type=aoi, aoi_id=22222}], addressLevel=aoi}
{linkLevel=aoi, list=[{address=汉东省京州市天山区高峰街道孽海社区卧龙大道1号元气森林香溪谷, town=高峰街道, city=京州市, county=天山区, community=孽海社区, type=aoi, aoi_id=11111, province=汉东省, road=卧龙大道, road_no=1, aoi=元气森林香溪谷, id=11111}], addressLevel=aoi}
2024-06-20 at 14:39:50 CST
2024-06-20 at 14:39:50 CST

至此就完成了

这篇关于如何根据地址获取对应的社区的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

通过高德api查询所有店铺地址信息

通过高德api查询所有店铺地址电话信息 需求:通过高德api查询所有店铺地址信息需求分析具体实现1、申请高德appkey2、下载types city 字典值3、具体代码调用 需求:通过高德api查询所有店铺地址信息 需求分析 查询现有高德api发现现有接口关键字搜索API服务地址: https://developer.amap.com/api/webservice/gui

时间服务器中,适用于国内的 NTP 服务器地址,可用于时间同步或 Android 加速 GPS 定位

NTP 是什么?   NTP 是网络时间协议(Network Time Protocol),它用来同步网络设备【如计算机、手机】的时间的协议。 NTP 实现什么目的?   目的很简单,就是为了提供准确时间。因为我们的手表、设备等,经常会时间跑着跑着就有误差,或快或慢的少几秒,时间长了甚至误差过分钟。 NTP 服务器列表 最常见、熟知的就是 www.pool.ntp.org/zo

【青龙面板辅助】JD商品自动给好评获取京豆脚本

1.打开链接 开下面的链接进入待评价商品页面 https://club.jd.com/myJdcomments/myJdcomments.action?sort=0 2.登陆后执行脚本 登陆后,按F12键,选择console,复制粘贴以下代码,先运行脚本1,再运行脚本2 脚本1代码 可以自行修改评价内容。 var content = '材质很好,质量也不错,到货也很快物流满分,包装快递满

开启青龙 Ninja 扫码功能失效后修改成手动填写CK功能【修正Ninja拉库地址】

国内:进入容器docker exec -it qinglong bash #获取ninjagit clone -b main https://ghproxy.com/https://github.com/wjx0428/ninja.git /ql/ninja#安装cd /ql/ninja/backend && pnpm install cp .env.example .env

局域网内vue2 配置本地IP地址访问项目

在日常开发中同事可能需要访问你的前端项目,可以通过配置实现通过ip访问 一.首先找到config文件夹目录下的 index.js文件             将此处的host的值修改为0.0.0.0(即 host: 0.0.0.0) // Various Dev Server settings//host: 'localhost' //将localhost进行替换成 0.0.0.0host:

Spring 内部类获取不到@Value配置值问题排查(附Spring代理方式)

目录 一、实例问题 1、现象 2、原因 3、解决 二、Spring的代理模式 1、静态代理(Static Proxy) 1)原理 2)优缺点 3)代码实现 2、JDK动态代理(JDK Dynamic Proxy) 1)原理 2)优缺点 3)代码实现 3、cglib 代理(Code Generation Library Proxy) 1)原理 2)优缺点 3)代码实

获取Windows系统版本号(转)

https://blog.csdn.net/sunflover454/article/details/51525179

ApplicationContext 获取的三种方法

spring为ApplicationContext提供的3种实现分别 为:ClassPathXmlApplicationContext,FileSystemXmlApplicationContext和 XmlWebApplicationContext,其中XmlWebApplicationContext是专为Web工程定制的。使用举例如下:    1. FileSystemXmlApplicati

剑指Offer—编程题56(链表中环的入口地址)

题目:一个链表中包含环,如何找出环的入口结点? 解题思路   可以用两个指针来解决这个问题。先定义两个指针P1和P2指向链表的头结点。如果链表中环有n个结点,指针P1在链表上向前移动n步,然后两个指针以相同的速度向前移动。当第二个指针指向环的入口结点时,第一个指针已经围绕着环走了一圈又回到了入口结点。    剩下的问题就是如何得到环中结点的数目。我们在面试题15的第二个相关题目时用到

理解什么是DSR,嗅探器视角下的IP和MAC地址识别(C/C++代码实现)

网络嗅探器是监控和分析网络流量的一种工具,它能够捕获数据包并提取出关键的信息,比如IP地址和MAC地址。 网络嗅探器工作原理基于网卡的工作模式。正常情况下,网卡只处理发送给它的数据包,忽略其他数据。但是,如果将网卡设置为“混杂模式”,那么它可以接收到网络上所有的数据包,而不仅仅是发给它的数据包。网络嗅探器就是利用了这一特性来捕获网络上的数据交换。 数据包是网络通信的基本单位,包含了传输数据和控