我正在寻找一个找到家庭信件的正则表达式模式。
Eks(寻找字母d)。
1. Streetname 3d, 7000 Town Country.
2. Streetname 3 d, 7000 Town Country.
3. Streetname 13d, 7000 Town Country.
4. Streetname 13 d, 7000 Town Country.
我在写C#。
答案 0 :(得分:2)
以下的一些组合:
const string address = "Streetname 3d, 7000 Town Country";
string streetPart = address.Split(',')[0];
char letter = streetPart[streetPart.Length - 1];
bool isLetter = char.IsLetter(letter);
Debug.WriteLine("{0}, isLetter: {1}", letter, isLetter);
可能会有用......
输出:d, isLetter: true
答案 1 :(得分:1)
我认为这种模式适用于你的4个案例。 我不测试代码,只是试试并告诉我。
string sPattern = "[a-zA-Z 0-9]*([a-zA-Z]),.*";
int i = 0;
foreach (string s in address)
{
Match m = Regex.Match(s, sPattern);
if (m.Success){
houseLetter[i] = m.ToString();
} else {
houseLetter[i] = "Not Found";
}
i++;
}
答案 2 :(得分:0)
如果您认为有一个普遍用于解决此问题的正则表达式,请不要再这样想了。根据您的计划,我父母的街道地址将是
Ioakim 3rd 4242, 7000 Town Country // "Ioakim 3rd" is the street name
如你所见,你肯定会有一定比例的错误结果。您的四个例子是唯一需要保证正确结果的案例吗?