-2

我有下面提到的字符串。

ISA*ABC**TODAY*ALEXANDER GONZALEZ~HL*CDD*DKKD*S~EB*1*AKDK**DDJKJ~AAA*Y**50*P~AAA*N**50*P~AAA*N**63*C~AAA*N**50*D~AAA*N**45*D

在上面的字符串中有段。每个段都以倾斜(〜)符号开始,我想检查是否存在出现 AAA 段的段,并且在它的第三个索引上存在数字 63。我需要一个正则表达式。我已经尝试过并想出了这个(~AAA),但由于我是正则表达式的新手,我不知道如何检查 63 是否出现在第三个索引上?如果有人可以提供帮助,我将非常感激。

4

4 回答 4

2

我必须同意塞巴斯蒂安的评论。这可以使用简单的Split操作来完成。

    private static bool Check(string input)
    {
        int count = 0;
        foreach (string segment in input.Split('~'))
        {
            string[] tokens = segment.Split('*');
            if (tokens[0] == "AAA")
            {
                count++;
                if (count == 3)
                {
                    if (tokens[3] == "63") return true;
                    else return false;
                }
            }
        }
        return false;
    }

编辑:既然你想要更少的代码行,那么 LINQ 怎么样?

    private bool Check(string input)
    {
        return input.Split('~').Select(x => x.Split('*')).Any(x => x.Length >= 4 && x[0].Equals("AAA") && x[3].Equals("63"));
    }

EDIT2:为了完整起见,这里还有一个正则表达式解决方案:

    private bool Check(string input)
    {
        return Regex.IsMatch(input, @".*~AAA\*([^\*~]*\*){2}63.*");
    }
于 2013-01-22T14:50:59.530 回答
0

很多很多的网站和工具可以帮助您使用正则表达式。谷歌可以进一步帮助你。

于 2013-01-22T14:43:05.650 回答
0
   string s = "ISA*ABC**TODAY*ALEXANDER GONZALEZ~HL*CDD*DKKD*S~EB*1*AKDK**DDJKJ~AAA*Y**50*P~AAA*N**50*P~AAA*N**63*C~AAA*N**50*D~AAA*N*   *45*D";
   string[] parts = s.Split('~');
   for (int i = 0; i < parts.Count(); i++)
   {
      MessageBox.Show("part "+i.ToString()+" contains 63: "+parts[i].Contains("63").ToString());
   }

这只是一个例子。你可以做更多,我检查了任何部分中是否存在 63。
因此,如果您确实想检查第 3 段代码是否为:

bool segment3Contains63 = s.Slplit('~')[3].Contains("63");
于 2013-01-22T14:43:39.163 回答
0

你可以使用这个:

~AAA\*[A-Z]\*\*63

注意 \ 用于转义 * 和 [AZ] 匹配任何大写字母字符。

于 2013-01-22T14:48:20.970 回答