Регулярное выражение в C # - PullRequest
3 голосов
/ 13 мая 2010

У меня есть текст, похожий на этот.

@@ MMIVLoader @ ProductVer @ 4.1.2 @ BCM_7400S_LE @ Product @ 21 августа 2009 г. @
@@ MMIVLib @ ObjectVer @ 4.1.2 @ BCM_7400S_LE @ Product @ 21 августа 2009 г. @
@@ HuaweFGDLDrv @ ObjectVer @ 01.00.09 @ 7324 @ PRODUCT @ 20 августа 2009 г. @
@@ ProtectVer @ ObjectVer @ 127.8.1 @ BCM_SDE5.03 @ PRODUCT @ 4 августа 2009 г. 06: 56: 19 @
@@ KernelSw @ ObjectVer @ 0.0.1 @ BCM-7454 @ PRODUCT @ 19.12.2007 @
@@ ReceiverSw @ ObjectVer @ E.5.6.001 @ HWBC01ZS @ PRODUCT @ 3 мая 2010 г. @

я хочу, чтобы выход был в массиве, как

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 ]

8 голосов
/ 13 мая 2010

Это просто, вы можете просто разделить на @ (удалив пустые элементы) и вытянуть первый и третий элементы.

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();
3 голосов
/ 13 мая 2010

Или просто удалите лишние вещи из строки

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

А затем просто разделите запятыми в каждой строке, чтобы получить массив

2 голосов
/ 13 мая 2010

Если вы хотите сумасшедшее решение для регулярных выражений, вы можете использовать это:

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"]);
}
0 голосов
/ 13 мая 2010

Для полноты, вот версия 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);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...