使用java将英国邮政编码拆分为两个主要部分

时间:2011-04-10 10:42:33

标签: java regex postal-code

这个用于验证邮政编码的正则表达式是完美的

^([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中完成?

3 个答案:

答案 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/