3

我有这样的文字。

@@MMIVLoader@ProductVer@4.1.2@BCM_7400S_LE@Product@2009 年 8 月 21 日@@@
MMIVLib@ObjectVer@4.1.2@BCM_7400S_LE@Product@2009 年 8 月 21 日@@@
HuaweFGDLDrv@ObjectVer@01.00.09@7324@PRODUCT@ 2009 年 8 月 20 日@@@
ProtectVer@ObjectVer@127.8.1 @BCM_SDE5.03@PRODUCT@2009 年 8 月 4 日
06:56:19@@@KernelSw@ObjectVer@0.0.1@BCM-7454@PRODUCT@ 2007 年 12 月 19 日
@@ @ReceiverSw@ObjectVer@E.5.6.001@HWBC01ZS@PRODUCT@2010 年 5 月 3 日@

我想把输出放在一个数组中

MMIVLoader 4.1.2
MMIVLib         4.1.2
HuaweFGDLDrv 01.00.09
ProtectVer 127.8.1 
KernelSw 0.0.1
ReceiverSw E.5.6.001

任何人都可以建议我如何使用正则表达式在 c# 中执行此操作,或者是否有任何复杂的方法来执行此操作

提前致谢

4

4 回答 4

8

这很简单,您可以只拆分@(删除空项目)并拉出第一个和第三个项目。

var list = myString.Split(new String[] {Environment.NewLine},
          StringSplitOptions.RemoveEmptyEntries)                
   .Select(item => item.Split(new char[] {'@'}, 
          StringSplitOptions.RemoveEmptyEntries))
   .Where(a => a.Length > 2)
   .Select(a => new { Item = a[0], Version = a[2] }).ToArray();
于 2010-05-13T07:11:53.933 回答
3

或者只是从行中删除多余的东西

Regex.Replace(text, @"^@@([^@]+)@[^@]+@([^@]+).*", "$1,$2",RegexOptions.Multiline);

要得到

MMIVLoader,4.1.2
MMIVLib,4.1.2
HuaweFGDLDrv,01.00.09
ProtectVer,127.8.1
KernelSw,0.0.1
ReceiverSw,E.5.6.001

然后,只需在每一行上用逗号分隔即可得到数组

于 2010-05-13T07:33:16.993 回答
2

如果你确实想要一个疯狂的正则表达式解决方案,你可以使用这个:

var matches = Regex.Matches(
    input,
    "@@(?<name>.*?)@(Product|Object)Ver@(?<ver>.*?)@",
    RegexOptions.IgnoreCase
).Cast<Match>().Select(m => m.Groups);

foreach (var match in matches)
{
    Console.WriteLine("{0} {1}", match["name"], match["ver"]);
}
于 2010-05-13T07:19:47.957 回答
0

为了完整起见,这里是一个带有查询语法的 LINQ 版本:)

string[] lines = new string[] { 
            "@@MMIVLoader@ProductVer@4.1.2@BCM_7400S_LE@Product@Aug 21 2009@",
            "@@MMIVLib@ObjectVer@4.1.2@BCM_7400S_LE@Product@Aug 21 2009@",
            "@@HuaweFGDLDrv@ObjectVer@01.00.09@7324@PRODUCT@Aug 20 2009@",
            "@@ProtectVer@ObjectVer@127.8.1 @BCM_SDE5.03@PRODUCT@Aug  4 2009 06:56:19@",
            "@@KernelSw@ObjectVer@0.0.1@BCM-7454@PRODUCT@ Dec 19 2007@",
            "@@ReceiverSw@ObjectVer@E.5.6.001@HWBC01ZS@PRODUCT@May  3 2010@" };
var q = from components in
           (from line in lines
            select line.Split(new char[] { '@' }, 
                     StringSplitOptions.RemoveEmptyEntries))
        select new { Name = components[0], Version = components[2] };
foreach (var item in q)
{
    Console.WriteLine("Item: Name={0} Version={1}", item.Name, item.Version);
}
于 2010-05-13T07:18:23.127 回答