解析此表的最简单方法是什么:

本文关键字:方法 是什么 最简单 | 更新日期: 2023-09-27 18:29:40

我有一个列表,我想在表单中显示它。但首先,我想移动所有不相关的部分。这是我的清单:

===================================================================
Protocol Hierarchy Statistics
Filter:
eth                                      frames:8753 bytes:6185473
  ip                                     frames:8753 bytes:6185473
    tcp                                  frames:8661 bytes:6166313
      http                               frames:1230 bytes:792126
        data-text-lines                  frames:114 bytes:82636
          tcp.segments                   frames:56 bytes:41270
        image-gif                        frames:174 bytes:109968
          tcp.segments                   frames:57 bytes:37479
        image-jfif                       frames:195 bytes:154407
          tcp.segments                   frames:185 bytes:142340
        png                              frames:35 bytes:30521
          tcp.segments                   frames:20 bytes:15770
        media                            frames:39 bytes:32514
          tcp.segments                   frames:32 bytes:24755
        tcp.segments                     frames:6 bytes:1801
        xml                              frames:5 bytes:3061
          tcp.segments                   frames:1 bytes:960
      ssl                                frames:20 bytes:14610
    udp                                  frames:92 bytes:19160
      dns                                frames:92 bytes:19160
===================================================================

我想显示第一列(协议类型),在第二列中只显示"帧:"之后的部分,没有字节:xxxx-

解析此表的最简单方法是什么:

可能使用Regex,类似于:

Regex rgx = new Regex(@"^(?<protocol>[ a-zA-Z0-9'-'.]*)frames:(?<frameCount>[0-9]).*$");   
   foreach (Match match in rgx.Matches(myListOfProtocolsAsAString))
   {
      if(match.Success)
      {
         string protocol = match.Groups[1].Value;
         int byteCount = Int32.Parse(match.Groups[2].Value);
      }
   }

然后,您可以访问Match实例上的匹配组(协议和帧数)。

使用一直流行的Linq到对象

var lines = new string[]
  {
    "eth                                    frames:8753 bytes:6185473",
    "ip                                     frames:8753 bytes:6185473"
  };
var values = lines.Select(
    line=>line.Split(new string[]{"frames:", "bytes:"}, StringSplitOptions.None))
    .Select (items => new {Name=items[0].Trim(), Value=items[1].Trim()});