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 地址提取省市县的主要内容,如果未能解决你的问题,请参考以下文章
EXCEL如何在地址栏中 提取姓名 联系电话 省 市 区/县 详细地址 邮编 等信息