excel 地址提取省市县

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了excel 地址提取省市县相关的知识,希望对你有一定的参考价值。

A 列: B列:
贵州省六盘水市水县陇脚镇补雨村 贵州省六盘水市
河南省桐柏县新集乡王寨村 河南省桐柏县
四川省南充市阆中市金子乡 四川省南充市
就是地址只提取到什么省什么市什么县,请高手帮忙!

1、如下图,是我制作的几个订单地址,我们就以此为源数据演示一下如何提取省市区及详细地址。

2、点击如下图选项方方格子。

3、点击更多。

4、点击提取地址。

5、在弹出对话框区域选项中选择地址数据区域,点击确定,选择一个存放单元格,点击确定即可完成。

参考技术A

工具/材料:excel 2007

1、首先打开一份需要提取省市县的表格。

2、开了之后a列是地址的全称,然后在b1里面输入公式=MID(A1,1,FIND("省",A1)),然后按回车键就将省提出提取出来。

3、接着在C1里面输入公式=MID(A1,FIND("省",A1)+1,FIND("市",A1)-FIND("省",A1)),接着按回车键就将市提取出来。

4、再接着在D1里面输入公式=MID(A1,FIND("市",A1)+1,FIND("县",A1)-FIND("市",A1)),按回车键就可以将县提取出来。

5、如图所示,就是输入了公式之后提取出来的省市县。

6、然后将B1C1D1单元格全部选中,并将光标放置D1右下角的点上。

7、然后将数据往下拉,将其他的单元格填充就可以将所有需要提取的单元格都设置完了。

参考技术B 复制A列到B列,然后选中整个B列,然后Ctrl+H,替换
查找内容为 市*
替换内容为 市
查找内容为 县*
替换内容为 县
替换的时候选择 全部替换
这样就把这一列的 市 和 县 后面的内容去掉了
参考技术C 第一行为表头,那么可以在B2中输入:
=IF(COUNTIF(A2,"*县*"),LEFT(A2,FIND("县",A2)),IF(COUNTIF(A2,"*市*"),LEFT(A2,FIND("市",A2)),""))
往下拉即可。本回答被提问者采纳
参考技术D 你这个不太好弄,
下面公式,可以达到的效果不一定完美
=LEFT(A1,MIN(IF(ISNUMBER(FIND("市",A1)),FIND("市",A1),10^10),IF(ISNUMBER(FIND("县",A1)),FIND("县",A1),10^10)))

Java正则表达式匹配地址获得省市县

正则表达式

正则表达式测试
正则表达式入门
匹配省、自治区以及四个直辖市作为省

((?<province>[^省]+省|.+自治区)|上海市|北京市|天津市|重庆市)

匹配市、自治州、区作为市

(?<city>[^市]+市|.+自治州|.+区)?

匹配县、市、区、镇、局作为县

(?<country>[^县]+县|.+市|.+区|.+镇|.+局)?

匹配区、镇作为镇

(?<town>[^区]+区|.+镇)?

匹配省市县镇以外其余数据

(?<village>.*)

正则表达式匹配地址获得省市县

import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * @Author zxy
 * @Date 2022-05-10
 * @Desc 使用正则表达式匹配省市县
 */
public class regex_address 
    /**
     * @Desc regexAddress()函数,传入地址,以List存储省市县
     * @param address
     * @return List<Map<String,String>>
     */
    public static List<Map<String,String>> regexAddress(String address)
        // 自定义正则表达式
        // 由于后续通过province分组无法获取到四个直辖市,所以在后续代码中再次处理,这里只需要匹配成功即可
        String regex = "((?<province>[^省]+省|.+自治区)|上海市|北京市|天津市|重庆市)(?<city>[^市]+市|.+自治州|.+区)?(?<country>[^县]+县|.+市|.+区|.+镇|.+局)?(?<town>[^区]+区|.+镇)?(?<village>.*)";
        // 使用regex正则表达式匹配address地址
        Matcher matcher = Pattern.compile(regex).matcher(address);
        // 初始化省市县
        String province = null,city = null,country = null;
        // 定义ArrayList<>()
        ArrayList<Map<String, String>> table = new ArrayList<>();
        Map<String,String> row = null;
        //匹配成功的情况
        while (matcher.find())
            row = new LinkedHashMap<String,String>();
            //自定义正则表达式2,用于匹配四个直辖市
            String regex2 = "(上海市|北京市|天津市|重庆市)";
            Matcher matcher1 = Pattern.compile(regex2).matcher(address);
            //如果匹配成功,则将直辖市复制给province变量
            if (matcher1.find())
                province = matcher1.group(1);
            else // 否则直接通过matcher从regex中根据分组province匹配获得
                province = matcher.group("province");
            row.put("province",province == null ? "":province.trim());
            city = matcher.group("city");
            row.put("city",city == null ? "" : city.trim());
            country = matcher.group("country");
            row.put("country",country == null ? "" : country);
            table.add(row);
        
        return table;
    
    public static void main(String[] args) 
        String[] addressList = "浙江省杭州市西湖区", "江苏省苏州市吴中区", "河南省郑州市新郑市","上海市浦东新区","河南省郑州市新郑市","北京市朝阳区";
        for(String address : addressList)
            System.out.println(address);
            List<Map<String, String>> address1 = regexAddress(address);
            String province = address1.get(0).get("province");
            String city = address1.get(0).get("city");
            String country = address1.get(0).get("country");
            System.out.printf("province:%s,city:%s,country:%s\\n",province,city,country);
        
    


输出结果

浙江省杭州市西湖区
province:浙江省,city:杭州市,country:西湖区
江苏省苏州市吴中区
province:江苏省,city:苏州市,country:吴中区
河南省郑州市新郑市
province:河南省,city:郑州市,country:新郑市
上海市浦东新区
province:上海市,city:浦东新区,country:
河南省郑州市新郑市
province:河南省,city:郑州市,country:新郑市
北京市朝阳区
province:北京市,city:朝阳区,country:

Process finished with exit code 0

以上是关于excel 地址提取省市县的主要内容,如果未能解决你的问题,请参考以下文章

利用PYTHON匹配提取EXCEL表的省市区,有偿?

Powerbi如何根据地址提炼省市

EXCEL如何在地址栏中 提取姓名 联系电话 省 市 区/县 详细地址 邮编 等信息

Excel-VBA正则表达式提取文本案例

在excel如何用函数把地址中省份、城市、区县单独提取出来?

Excel函数实现从地址中筛选省市