我正在编写一些软件,我必须从外部文件加载很多列名。通常我会用一些JSON来做这件事,但出于用户友好的原因,我现在不能这样做。我需要使用一个对用户可读的文本文件,并包含很多注释。
所以我创建了自己的文件来保存所有这些值。
现在,当我在我的软件中导入这些值时,我基本上逐行遍历我的配置文件,如果它匹配我随后解析的参数,我会检查每一行。但是这样我最终得到了一个带有非常重复代码的大代码块,我想知道是不能以某种方式简化它,以便每一次检查都只需要一行。
这是我目前使用的代码:
if (line.Contains("[myValue]"))
{
myParameter = line.Replace("[myValue]", string.Empty).Trim();
}
我知道使用Linq你可以简单地将它们放在一行中,我只是不确定它是否适用于这种情况?
谢谢你的帮助!肯尼斯
如果这段代码经常重复,为什么不创建一个方法:
void SetParameter(string line, string name, ref string parameter)
{
if (line.Contains(name))
{
parameter = line.Replace(name, string.Empty).Trim();
}
}
SetParameter(line, "[myValue]", ref myParameter);
如果你想避免同时调用Replace
和Contains
,这可能是一个好主意,你也可以调用Replace
:
void SetParameter(string line, string name, ref string parameter)
{
var replaced = line.Replace(name, string.Empty);
if (line != replaced)
{
parameter = replaced.Trim();
}
}
试试这种方式(三元):
myParameter = line.Contains("[myValue]")?line.Replace("[myValue]", string.Empty).Trim():myParameter;
其实,
line.IndexOf
应该更快。
从你的代码看,你看起来只是用空文本替换,所以为什么不采取整个字符串(由许多行组成)并一次替换,而不是一次检查一行。
您可以使用RegEx。这可能会减轻一些重复的代码
string line = "[myvalue1] some string [someotherstring] [myvalue2]";
// All your Keys stored at a single place
string[] keylist = new string[] { @"\[myvalue1]", @"\[myvalue2]" };
var newString = Regex.Replace(line, string.Join("|", keylist), string.Empty);
希望能帮助到你。