我正在读取一个 csv 文件,该文件的第一行包含列名称,第 >1 行包含值。我需要获取列名称的位置。我能想到的唯一方法是执行 switch 或 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
最佳答案
是什么阻止您使用循环?
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;
}
}
...
要保持与 if
else if
相同的功能,您可以在条件语句中使用 break
。
编辑:编辑现在清楚地表明 contains 中的字符串没有明确的模式。尽管如此,如果您要编写 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;
}
}
...
关于c# - 许多 else 和 if 语句?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18263035/