c# 将json转换为csv文件
时间: 2024-01-14 09:04:22 浏览: 254
CSV文件转换.zip
你可以使用 C# 中的 Newtonsoft.Json 库来将 JSON 转换为 CSV 文件。下面是一个简单的示例代码:
```csharp
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System;
using System.Collections.Generic;
using System.IO;
class Program
{
static void Main(string[] args)
{
// 读取 JSON 文件内容
string json = File.ReadAllText("input.json");
// 将 JSON 解析为对象
var data = JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(json);
// 获取所有属性名作为 CSV 的表头
var headers = new List<string>(data[0].Keys);
// 创建 CSV 文件并写入表头
using (var writer = new StreamWriter("output.csv"))
{
writer.WriteLine(string.Join(",", headers));
// 逐行写入数据
foreach (var item in data)
{
var values = new List<string>();
// 按照表头的顺序获取每个属性的值
foreach (var header in headers)
{
values.Add(item.ContainsKey(header) ? item[header] : "");
}
writer.WriteLine(string.Join(",", values));
}
}
Console.WriteLine("CSV 文件已生成!");
}
}
```
在这个示例中,我们假设输入的 JSON 数据是一个包含多个对象的数组,每个对象都是一个字典。通过使用 Newtonsoft.Json 库,我们可以将 JSON 字符串反序列化为一个包含字典的列表。然后,我们提取出所有属性名作为 CSV 文件的表头,并逐行写入每个对象的属性值。
记得替换代码中的 `input.json` 和 `output.csv` 分别为你的输入 JSON 文件和输出 CSV 文件的路径。确保你已经将 Newtonsoft.Json 包添加到你的项目中。
希望对你有所帮助!如果有任何进一步的问题,请随时提问。
阅读全文