2

我正在读取一个 csv 文件,该文件在第一行包含列名,在 >1 行包含值。我需要获取列名的位置。我能想到的唯一方法是切换或ifs。我在某处读到它,就我而言,执行 ifs 更快(更好)。但是该文件有很多列(~120)。只是想知道是否有替代方案。

private static void Get_Position(string line, performance p)
{
    string[] line_split = line.Split(',');
    for (int i = 0; i < line_split.Length; i++)
    {
       if (line_split[i].Contains(@"(0)\% Processor Time"))
        {
            p.percore[0] = i;
        }
        else if (line_split[i].Contains(@"(1)\% Processor Time"))
        {
            p.percore[1] = i;
        }
        else if (line_split[i].Contains("Private Bytes"))
        {}
        else if (line_split[i].contains("DPC")
        {
         }

        //on and on and on with else ifs
4

1 回答 1

6

是什么阻止您使用循环?

for (int i = 0; i < line_split.Length; i++)
{
   for(var j = 0; j < 120; j++)
   {
      if(line_split[i].Contains(@"(" + j + ")\% Processor Time"))
      {
         p.percore[j] = i;
      }
   }
...

要保持与 then 相同的功能,if else if您可以break在条件内使用 a 。

编辑:编辑现在清楚地表明包含中的字符串没有明确的模式。尽管如此,如果您要写出 120 个 if/else if 语句,您应该将要查找的内容存储在某种类型的集合中。例如,一个列表就可以了。j然后访问循环中集合的索引:

...
var listOfSearchItems = new List<string>() { "Private Bytes", "DPC" };

for (int i = 0; i < line_split.Length; i++)
{
   for(var j = 0; j < 120; j++)
   {
      if(line_split[i].Contains(listOfSearchItems[j])
      {
         p.percore[j] = i;
      }
   }
...
于 2013-08-15T22:40:53.503 回答