在我有一个可以直接写入代码的修复项之前:
public static string GetCsvStringFormat(int count)
{
var sb = new StringBuilder();
for (int i = 0; i < count; i++)
{
sb.AppendFormat("{{{0}}};", i);
}
return sb.ToString();
}
return string.Format(
RefTypeParseExtension.GetCsvStringFormat(3),
"No Id","Article","Amount"
);
但现在该项目是动态的,可能只有1个或2个或更多项目。
我试过数组:
string[] Tete = { "No Id","Article","Amount","IsFix"}
string temp = "";
for (int i = 0; i < Tete.Length; i++)
{
if (i != Tete.Length-1) { temp += "\"" + Tete[i] + "\","; }
else { temp += "\"" + Tete[i] + "\""; }
}
return string.Format(
RefTypeParseExtension.GetCsvStringFormat(Tete.Length),
temp
);
我也尝试过使用字符串构建器:
public static string GetTete(string[] Tete)
{
var sb = new StringBuilder();
for (int i = 0; i < Tete.Length; i++)
{
if (i != Tete.Length - 1) { sb.AppendFormat("\"{0}\",", Tete[i]); }
else { sb.AppendFormat("\"{0}\"", Tete[i]); }
}
return sb.ToString();
}
我都收到同样的错误:
索引(零基数)必须大于或等于零且小于参数列表的大小。
即使数组和字符串生成器的结果返回完全一样。
我可能在这里遗漏了一些东西,但你的第一个代码示例正在使用接受String.Format
和string
的params object[] args
的重载 - 所以我认为你应该这样做:
public static string GetTete(string[] Tete)
{
return string.Format(RefTypeParseExtension.GetCsvStringFormat(Tete.Length), Tete);
}