c# - 将动态对象列表读入 CSV

标签 c# csv dynamic reflection

我正在尝试将大量数据读取到平面 CSV 中。每行的一个字段是 XML 数据 - XML 指示每一行中的附加属性。因此,每一行的属性可能略有不同。

我在初始结构化类中得到了我的列表:

private class Response {
    public Response() {
        Values = new Dictionary<string, string>();
    }

    public string Owner { get; set; }
    public string Author { get; set; }
    public string Email { get; set; }
    public string Data { get; set; } // XML data in here
    public Dictionary<string, string> Values { get; set; }
    public DateTime Created { get; set; }
}

然后我想使我的列表动态化以处理各种属性:

var responses = new List<dynamic>();
foreach (var response in query) {
    if (!string.IsNullOrEmpty(response.Data))
    {
        var doc = new XmlDocument();
        doc.LoadXml(response.Data);

        foreach (XmlNode node in doc.GetElementsByTagName("field")) {
        try
        {
            response.Values.Add(node.FirstChild.InnerText, node.LastChild.InnerText);
        }
        catch (Exception ex) {
            // log
        }
    }
}

            dynamic fullResponse = new ExpandoObject();
            fullResponse.Owner = response.Owner;
            fullResponse.Author = response.Author;
            fullResponse.Email = response.Email;
            fullResponse.Created = response.Created;

            IDictionary<string, object> map = fullResponse;
            foreach (var value in response.Values) {
                if (map.ContainsKey(value.Key)) {
                    map[value.Key] = value.Value;
                }
                else {
                    map.Add(value.Key, value.Value);
                }
            }

            responses.Add(fullResponse);
        }

... 这也很好用。但现在我想基本展平此列表并将其导出为 CSV,因为我知道我的动态列表的每一行可能具有略微不同的属性。

抓取PropertyInfo,一个动态类型,显然什么也得不到。我是否只需要遍历我的列表以手动将唯一属性提取到 DataTable 之类的东西中?或者我可以用 Reflection 进行一些调用以更有效地完成这项工作吗?

最佳答案

我最终使用了一个普通的旧 DataTable 来对其进行排序:

using (var dt = new DataTable())
{
     var keys = responses.SelectMany(x => ((IDictionary<string, object>)x).Keys).Distinct();
     var columns = keys.Select(x => new DataColumn(x)).ToArray();
     dt.Columns.AddRange(columns);

     foreach(IDictionary<string, object> response in responses)
     {
         var row = dt.NewRow();
         foreach (var kvp in response)
         {
             row[kvp.Key] = kvp.Value;
         }
         dt.Rows.Add(row);
     }

     // write to CSV
}

虽然我觉得我可以用反射做一些更酷的事情来达到同样的结果。

关于c# - 将动态对象列表读入 CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24043659/

相关文章:

python - 使用格式化函数没有得到我想要的

excel - 将 CSV 文件导入 Excel

javascript - 动态加载外部 javascript 并将其绑定(bind)到特定的 DOM 元素或命名空间

c - 指向结构的指针和指向结构指针数组的指针。 C中的动态内存

c++ - 调用 delete[] 会破坏我的 C++ 程序

使用 ThreadPool 的 C# Execute 方法(带参数)

c# - 如何在 C# 中将 jpg 转换为 webp

c# - 如何删除Point结构的值?

c# - WebAPI 中的文件上传

php - CSV导入功能在插入mysql数据库时添加前面的双引号