将列表写入csv文件c#

时间:2015-07-27 12:05:17

标签: c# csv io

想象一下,我有两个充满值的列表。我想要第一个列表中的所有元素,写入第一列,第二个列表中的所有元素写入第二列,依此类推。

如果两个列表具有相同的大小,则可以正常工作:

 for (int i = 0; i < valueArray.Count(); i++)
 {
      var newLine = string.Format("{0},{1}", valueArray.ElementAt(i), secondValueArray.ElementAt(i));
      sw.Write(newLine);
 }

我的问题是,如果列表的大小不同,代码就会失败,显然会超出范围异常。我尝试在列之间添加','但它不起作用。

3 个答案:

答案 0 :(得分:6)

而不是ElementAt,您应该使用ElementAtOrDefault

根据msdn

  

返回序列中指定索引处的元素或默认值   索引超出范围时的值。

答案 1 :(得分:0)

试试这个:

List<int?> valueArray = new List<int?>();
List<int?> secondValueArray = new List<int?>();

//... fill lists
valueArray.Add( 1 );
valueArray.Add(2);
valueArray.Add(3);

secondValueArray.Add( 4 );

while (valueArray.Count > secondValueArray.Count)
    secondValueArray.Add(null);

while (secondValueArray.Count > valueArray.Count)
    valueArray.Add(null);

for (int i = 0; i < valueArray.Count(); i++)
{
    var newLine = string.Format("{0},{1}", valueArray.ElementAt(i), secondValueArray.ElementAt(i));
    Console.WriteLine(newLine);
}

;

结果:

1,4
2,
3,

答案 2 :(得分:0)

如前所述,使用ElementAtOrDefault()。并检查哪个阵列是最长的。此外,如果没有值,您可能希望写一个空字符串而不是NULL。

 int count = Math.Max(firstArray.Count(), secondArray.Count());

 for (int i = 0; i < count; i++)
 {
      var value1 = firstArray.ElementAtOrDefault(i) ?? String.Empty;
      var value2 = secondArray.ElementAtOrDefault(i) ?? String.Empty;

      var newLine = string.Format("{0},{1}", value1, value2);
      sw.Write(newLine);
 }