字符串生成器和字符串格式的构造字符串

问题描述 投票:-1回答:1

在我有一个可以直接写入代码的修复项之前:

 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();
}

我都收到同样的错误:

索引(零基数)必须大于或等于零且小于参数列表的大小。

即使数组和字符串生成器的结果返回完全一样。

c# string string-formatting
1个回答
1
投票

我可能在这里遗漏了一些东西,但你的第一个代码示例正在使用接受String.Formatstringparams object[] args的重载 - 所以我认为你应该这样做:

public static string GetTete(string[] Tete)
{
    return string.Format(RefTypeParseExtension.GetCsvStringFormat(Tete.Length), Tete);
}
© www.soinside.com 2019 - 2024. All rights reserved.