这个用于验证邮政编码的正则表达式是完美的
^([Gg][Ii][Rr] 0[Aa]{2})|((([A-Za-z][0-9]{1,2})|(([A-Za-z][A-Ha-hJ-Yj-y][0-9]{1,2})|(([A-Za-z][0-9][A-Za-z])|([A-Za-z][A-Ha-hJ-Yj-y][0-9]?[A-Za-z])))) {0,1}[0-9][A-Za-z]{2})$
但我想拆分邮政编码,以便使用java检索邮政编码的各个部分。
如何在java中完成?
答案 0 :(得分:5)
以下是匹配英国邮政编码的官方正则表达式:
http://interim.cabinetoffice.gov.uk/media/291370/bs7666-v2-0-xsd-PostCodeType.htm
如果你想将找到的邮政编码分成两部分,是不是只是在空白上拆分的问题?英国邮政编码的两个部分只是用空格隔开,对吗?在java中,这将是:
String[] fields = postcode.split("\\s");
其中邮政编码是经过验证的邮政编码,而字段[]将是包含第一和第二部分的长度为2的数组。
编辑:如果这是为了验证用户输入,并且您想要验证第一部分,那么您的正则表达式将是:
Pattern firstPart = Pattern.compile("[A-Z]{1,2}[0-9R][0-9A-Z]?");
验证第二部分是:
Pattern secondPart = Pattern.compile("[0-9][A-Z-[CIKMOV]]{2}");
答案 1 :(得分:1)
我意识到自问这个问题以来已经很长时间了,但我有同样的要求,并认为我会发布我的解决方案,以防有人在那里帮助:
const string matchString = @"^(?<Primary>([A-Z]{1,2}[0-9]{1,2}[A-Z]?))(?<Secondary>([0-9]{1}[A-Z]{2}))$";
var regEx = new Regex(matchString);
var match = regEx.Match(Postcode);
var postcodePrimary = match.Groups["Primary"];
var postcodeSecondary = match.Groups["Secondary"];
这不会验证邮政编码,但如果它们之间没有输入空格,它会将其分成两部分。
答案 2 :(得分:-1)
您可以使用Google最近的开源库。 http://code.google.com/p/libphonenumber/