c# - 将长度不等的列写入 CSV

标签 c# csvhelper

我在 C# 中反序列化了一个具有以下数据结构的 JSON 文件

[DataContract]
public class SentimentData
{
    [DataMember(Name ="Column1")]
    public IEnumerable<string> Column1 { get; set; }

    [DataMember(Name ="Column-2")]
    public IEnumerable<string> Column2 { get; set; }
}

column1 的计数不等于column2 的计数。我只是想基本上转储第一列中的第 1 列中的所有数据和第二列中的第 2 列中的数据。我尝试了以下方法,但没有成功。

using (var writer = new StreamWriter(@"C:\test.csv"))
{
    var nr = column1data.Select(y => new { Column1= y }).ToList();
    //var nnr = column2data.Select(y => new { Column2 = y }).ToList();

    var csv = new CsvWriter(writer);
    csv.WriteRecords(nr);
    //csv.WriteRecords(nnr);
    writer.Flush();
}

谁能知道如何做到这一点吗?

示例 json:

{
  "Negative": [
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt"
  ],
  "Non-Negative": [
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt",
    "a.txt",
    "b.txt"
  ]
}

最佳答案

下面的修改版代码为默认Enumerable.Zip

派生以下扩展以允许压缩不等长度的集合

public static class MyEnumerablExtensions {

    public static IEnumerable<TResult> ZipOrDefault<TFirst, TSecond, TResult>(this IEnumerable<TFirst> first, IEnumerable<TSecond> second, Func<TFirst, TSecond, TResult> resultSelector) {
        if (first == null) throw Error.ArgumentNull("first");
        if (second == null) throw Error.ArgumentNull("second");
        if (resultSelector == null) throw Error.ArgumentNull("resultSelector");
        using (IEnumerator<TFirst> e1 = first.GetEnumerator()) {
            using (IEnumerator<TSecond> e2 = second.GetEnumerator()) {
                while (e1.MoveNext()) {
                    if (e2.MoveNext()) {
                        yield return resultSelector(e1.Current, e2.Current);
                    } else {
                        yield return resultSelector(e1.Current, default(TSecond));
                    }
                }
                while (e2.MoveNext()) {
                    yield return resultSelector(default(TFirst), e2.Current);
                }
            }
        }
    }
    class Error {
        public static Exception ArgumentNull(string parameter) {
            return new ArgumentNullException(parameter);
        }
    }
}

这将允许您构建所需的对象模型,然后将其写入 CSV 编写器

using (var writer = new StreamWriter(@"C:\test.csv")) {
    var records = column1data.ZipOrDefault(column2data, 
        (Column1, Column2) => new { Column1, Column2 });

    var csv = new CsvWriter(writer);
    csv.WriteRecords(records);
    writer.Flush();
}

关于c# - 将长度不等的列写入 CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52552219/

相关文章:

c# - CsvHelper - 异步读取流

C# - 注册 COM 可见类所需的依赖 dll?

c# - 在jquery中设置对话框文本

c# - 使用 ASP.Net Core 中间件启动后台任务

c# - 可以使用 Assert 作为前置条件吗?

c# - CsvHelper 将映射器一个属性写入多列

c# - 无法在 MVC 操作中返回 CSV 文件。 Not 无法访问已关闭的 Streamable

c# - CsvWriter,CS1503 参数 2 : cannot convert CultureInfo

c# - Json.net忽略子对象的空值

c# - 使用 CSVhelper C# 合并具有不同 header 的 CSV 文件