欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實現(xiàn)根據(jù)地址智能識別省市區(qū)縣

 更新時間:2025年03月05日 09:34:00   作者:Javaの甘乃迪  
這篇文章主要為大家詳細介紹了如何編寫一個Java工具類,可以根據(jù)身份證地址或用戶輸入的地址,智能識別并提取出詳細的省市區(qū)縣信息,感興趣的小伙伴可以了解下

一、需求

根據(jù)OCR識別出的身份證地址或者用戶輸入的地址,智能識別出用戶的省、市、區(qū)/縣和詳細地址信息。

二、思路

解析給到接口的完整地址fullAddress,逐個匹配省province、市city、區(qū)/縣area、詳細地址detail,然后將 province+city+area+detail 返回即可。

PS:需要考慮一些情況:

1、四個直轄市(北京市、上海市、天津市、重慶市)。直轄市的完整地址fullAddress只有省、縣/區(qū)

2、完整地址fullAddress只有省、區(qū)/縣

3、市與區(qū)/縣重名

4、區(qū)/縣與區(qū)/縣重名

三、實現(xiàn)代碼

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
 
import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
 
/**
 * 身份證信息分析工具類Util
 */
@Slf4j
public class AnalysisIdCardUtil {
 
    /**
     * 獲取詳細地址
     *
     * @param fullAddress 身份證完整地址
     */
    public static String getDetailedAddress(String fullAddress) {
        String[] addressArrays = spliceDetailedAddress(fullAddress);
        return addressArrays[addressArrays.length - 1];
    }
 
    /**
     * 獲取省市區(qū)地址,如:安徽省合肥市包河區(qū)
     *
     * @param fullAddress 身份證完整地址
     */
    public static String getPcaAddress(String fullAddress) {
        String[] addressArrays = spliceDetailedAddress(fullAddress);
        StringBuilder areaBuffer = new StringBuilder();
        for (int i = 0; i < addressArrays.length - 1; i++) {
            if (StringUtils.isNotEmpty(addressArrays[i])) {
                areaBuffer.append(addressArrays[i]);
            }
        }
        return areaBuffer.toString();
    }
 
    /**
     * 身份證完成地址拆分為[省、市、區(qū)、詳細地址]數(shù)組,如:[安徽省, 合肥市, 包河區(qū), 幸福大街001號]
     *
     * @param fullAddress 身份證完整地址
     */
    public static String[] spliceDetailedAddress(String fullAddress) {
        String[] arr = new String[4];
        try {
            String tempStr = fullAddress;
            // 省
            String province = null;
            int provinceIdx = processProvince(tempStr);
            if (provinceIdx > -1) {
                province = tempStr.substring(0, provinceIdx + 1);
                tempStr = tempStr.substring(provinceIdx + 1);
            }
            // 市
            String city = null;
            int cityIdx = processCity(tempStr);
            if (cityIdx > -1) {
                city = tempStr.substring(0, cityIdx + 1);
                tempStr = tempStr.substring(cityIdx + 1);
            }
            // 區(qū)
            String county = null;
            int countyIdx = processCounty(tempStr);
            if (countyIdx > -1) {
                county = tempStr.substring(0, countyIdx + 1);
                tempStr = tempStr.substring(countyIdx + 1);
            }
            String street = tempStr;
            arr[0] = province;
            arr[1] = city;
            arr[2] = county;
            arr[3] = street;
        } catch (Exception e) {
            log.error("身份證詳細地址轉義失?。簕}", e.getMessage());
        }
        return arr;
    }
 
    /**
     * 拆分身份證完整地址中的省份信息
     *
     * @param address 地址
     */
    private static int processProvince(String address) {
        int[] idx = new int[3];
        int provinceIdx;
        if ((provinceIdx = address.indexOf("省")) > -1) {
            idx[0] = provinceIdx;
        }
        if ((provinceIdx = address.indexOf("市")) > -1) {
            idx[1] = provinceIdx;
        }
        if ((provinceIdx = address.indexOf("區(qū)")) > -1) {
            idx[2] = provinceIdx;
        }
        Arrays.sort(idx);
        for (int j : idx) {
            if (j > 0) {
                return j;
            }
        }
        return provinceIdx;
    }
 
    /**
     * 拆分身份證完整地址中的市區(qū)/縣/自治州信息
     *
     * @param address 地址
     */
    private static int processCity(String address) {
        int[] idx = new int[7];
        int cityIdx = -1;
        if ((cityIdx = address.indexOf("縣")) > -1) {
            idx[0] = cityIdx;
        }
        if ((cityIdx = address.indexOf("自治州")) > -1) {
            idx[1] = cityIdx + 2;
        }
        if ((cityIdx = address.indexOf("市轄區(qū)")) > -1) {
            idx[2] = cityIdx + 2;
        }
        if ((cityIdx = address.indexOf("市")) > -1) {
            idx[3] = cityIdx;
        }
        if ((cityIdx = address.indexOf("區(qū)")) > -1) {
            idx[4] = cityIdx;
        }
        if ((cityIdx = address.indexOf("地區(qū)")) > -1) {
            idx[5] = cityIdx + 1;
        }
        if ((cityIdx = address.indexOf("盟")) > -1) {
            idx[6] = cityIdx;
        }
        Arrays.sort(idx);
        for (int j : idx) {
            if (j > 0) {
                return j;
            }
        }
        return cityIdx;
    }
 
    /**
     * 拆分身份證完整地址中的縣/旗/島信息
     *
     * @param address 地址
     */
    private static int processCounty(String address) {
        int[] idx = new int[6];
        int countyIdx;
        if ((countyIdx = address.indexOf("縣")) > -1) {
            idx[0] = countyIdx;
        }
        if ((countyIdx = address.indexOf("旗")) > -1) {
            idx[1] = countyIdx;
        }
        if ((countyIdx = address.indexOf("海域")) > -1) {
            idx[2] = countyIdx + 1;
        }
        if ((countyIdx = address.indexOf("市")) > -1) {
            idx[3] = countyIdx;
        }
        if ((countyIdx = address.indexOf("區(qū)")) > -1) {
            idx[4] = countyIdx;
        }
        if ((countyIdx = address.indexOf("島")) > -1) {
            idx[5] = countyIdx;
        }
        Arrays.sort(idx);
        for (int j : idx) {
            if (j > 0) {
                return j;
            }
        }
        return countyIdx;
    }
 
    /**
     * 身份證地址提取省市區(qū)
     *
     * @param fullAddress 身份證完整地址
     */
    public static Map<String, String> addressResolution(String fullAddress) {
        // 定義正則
        String regex = "(?<province>[^省]+自治區(qū)|.*?省|.*?行政區(qū)|.*?市)(?<city>[^市]+自治州|.*?地區(qū)|.*?行政單位|.+盟|市轄區(qū)|.*?市|.*?縣)(?<area>[^縣]+縣|.+區(qū)|.+市|.+旗|.+海域|.+島)?(?<town>[^區(qū)]+區(qū)|.+鎮(zhèn))?(?<detail>.*)";
 
        Matcher matcher = Pattern.compile(regex).matcher(fullAddress);
        String province, city, area, town, detail;
        Map<String, String> map = new LinkedHashMap<>();
 
        while (matcher.find()) {
            province = matcher.group("province");
            map.put("province", StringUtils.isEmpty(province) ? "" : province.trim());
 
            city = matcher.group("city");
            map.put("city", StringUtils.isEmpty(city) ? "" : city.trim());
 
            area = matcher.group("area");
            map.put("area", StringUtils.isEmpty(area) ? "" : area.trim());
 
            town = matcher.group("town");
            map.put("town", StringUtils.isEmpty(town) ? "" : town.trim());
 
            detail = matcher.group("detail");
            map.put("detail", StringUtils.isEmpty(detail) ? "" : detail.trim());
        }
        return map;
    }
 
    public static void main(String[] args) {
 
        String address1 = "上海市上海市浦東新區(qū)世紀大道xx號上海中心大廈xx樓A座";
        String address2 = "內(nèi)蒙古自治區(qū)呼倫貝爾市鄂溫克族自治旗額爾古納市阿爾山北路xxx號蒙古民族文化博物館x樓xx展廳";
        String address3 = "廣東省廣州市番禺區(qū)沙灣鎮(zhèn)大巷涌路xxx號";
 
        System.out.println("詳細地址1:" + getDetailedAddress(address1));
        System.out.println("詳細地址2:" + getDetailedAddress(address2));
        System.out.println("省市區(qū)地址拼接1:" + getPcaAddress(address1));
        System.out.println("省市區(qū)地址拼接2:" + getPcaAddress(address2));
        System.out.println("地址數(shù)組1:" + Arrays.toString(spliceDetailedAddress(address1)));
        System.out.println("地址數(shù)組2:" + Arrays.toString(spliceDetailedAddress(address2)));
 
        System.out.println("地址提取省市區(qū):" + addressResolution(address2));
        System.out.println("地址提取省市區(qū):" + addressResolution(address3));
    }
}

測試結果:

到此這篇關于Java實現(xiàn)根據(jù)地址智能識別省市區(qū)縣的文章就介紹到這了,更多相關Java地址識別省市區(qū)縣內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 解決java執(zhí)行cmd命令調(diào)用ffmpeg報錯Concat error - No such filter ''[0,0]''問題

    解決java執(zhí)行cmd命令調(diào)用ffmpeg報錯Concat error - No such filter ''[0,0]

    這篇文章主要介紹了java執(zhí)行cmd命令,調(diào)用ffmpeg報錯Concat error - No such filter '[0,0]'解決方法,本文通過截圖實例代碼說明給大家介紹的非常詳細,對大家的工作或學習有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • java 二叉查找樹實例代碼

    java 二叉查找樹實例代碼

    這篇文章主要介紹了java 二叉查找樹實例代碼的相關資料,需要的朋友可以參考下
    2017-03-03
  • springboot整合Mybatis、JPA、Redis的示例代碼

    springboot整合Mybatis、JPA、Redis的示例代碼

    這篇文章主要介紹了springboot整合Mybatis、JPA、Redis的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Java隊列數(shù)據(jù)結構的實現(xiàn)

    Java隊列數(shù)據(jù)結構的實現(xiàn)

    這篇文章主要介紹了Java隊列數(shù)據(jù)結構的實現(xiàn),隊列是一種特殊的線性表,只允許在表的隊頭進行刪除操作,在表的后端進行插入操作,隊列是一個有序表先進先出,想了解更多相關資料的小伙伴可以參考下面文章的詳細內(nèi)容
    2021-12-12
  • startJVM錯誤Unable to load native library: libjvm.so解決方法

    startJVM錯誤Unable to load native library: libjvm.so解決方法

    這篇文章主要介紹了startJVM錯誤Unable to load native library: libjvm.so解決方法,需要的朋友可以參考下
    2014-07-07
  • SpringBoot實現(xiàn)釘釘機器人消息推送的示例代碼

    SpringBoot實現(xiàn)釘釘機器人消息推送的示例代碼

    這篇文章主要介紹了SpringBoot實現(xiàn)釘釘機器人消息推送的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • minio的原理、部署、操作方法(十分鐘精通MinIO)

    minio的原理、部署、操作方法(十分鐘精通MinIO)

    MinIO是一個簡單易用的云存儲服務,可以將文件上傳到互聯(lián)網(wǎng)上,方便在不同地方訪問,部署MinIO需要拉取鏡像、啟動端口、設置賬號密碼和映射文件地址,在Spring?Boot中集成MinIO,需要添加依賴、創(chuàng)建客戶端并進行單元測試,感興趣的朋友一起看看吧
    2025-02-02
  • Spring注解@Configuration和@Component區(qū)別詳解

    Spring注解@Configuration和@Component區(qū)別詳解

    @Component和@Configuration都可以作為配置類,之前一直都沒覺得這兩個用起來有什么差別,可能有時程序跑的和自己想的有所區(qū)別也沒注意到,下面這篇文章主要給大家介紹了關于Spring注解@Configuration和@Component區(qū)別的相關資料,需要的朋友可以參考下
    2023-04-04
  • Java并發(fā)編程學習之Unsafe類與LockSupport類源碼詳析

    Java并發(fā)編程學習之Unsafe類與LockSupport類源碼詳析

    這篇文章主要給大家介紹了關于Java并發(fā)編程學習之Unsafe類與LockSupport類源碼的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧
    2018-06-06
  • java sqlserver text 類型字段讀取方法

    java sqlserver text 類型字段讀取方法

    有這樣一個需求,需要將原本存儲在數(shù)據(jù)庫中的文檔轉存至文件系統(tǒng)中,于是寫了一個簡單的程序完成此功能
    2012-11-11

最新評論