C# | DataGridView数据转存为Json、XML格式

简介: DataGridView是常用的数据展示组件,而将其转存为Json或XML格式,则可以方便地进行数据的传输和存储。Json格式具有轻量、易读、易解析等优点,广泛应用于Web开发、API接口传输等场景。XML格式则具有良好的结构化特性,支持命名空间、数据类型等复杂数据表示方式,被广泛应用于数据交换、配置文件等领域。因此,将DataGridView数据转存为Json、XML格式,不仅能够方便地进行数据的传输和存储,还能够满足不同场景下的数据需求。本篇文章将介绍如何将DataGridView数据转存为Json、XML格式,并提供相应的代码示例。

image.png

C# | DataGridView数据转存为Json、XML格式

@[toc]

前言

DataGridView是常用的数据展示组件,而将其转存为Json或XML格式,则可以方便地进行数据的传输和存储。
Json格式具有轻量、易读、易解析等优点,广泛应用于Web开发、API接口传输等场景。
XML格式则具有良好的结构化特性,支持命名空间、数据类型等复杂数据表示方式,被广泛应用于数据交换、配置文件等领域。
因此,将DataGridView数据转存为Json、XML格式,不仅能够方便地进行数据的传输和存储,还能够满足不同场景下的数据需求。

本篇文章将介绍如何将DataGridView数据转存为Json、XML格式,并提供相应的代码示例。


DataGridView数据转为JSON数组

要将 DataGridView 中的数据转为 JSON 数组,首先需要遍历 DataGridView 的每一行和每个单元格,将数据以 Dictionary 的形式保存到 List> 中。
然后,使用 Newtonsoft.Json 库的 JsonConvert.SerializeObject 方法将数据转为 JSON 格式的字符串。

// 获取 DataGridView 的数据
List<Dictionary<string, object>> data = new List<Dictionary<string, object>>();
foreach (DataGridViewRow row in dataGridView1.Rows)
{
   
   
    Dictionary<string, object> rowData = new Dictionary<string, object>();
    foreach (DataGridViewCell cell in row.Cells)
    {
   
   
        rowData[cell.OwningColumn.HeaderText] = cell.Value;
    }
    data.Add(rowData);
}

// 将数据转为 JSON 数组
string json = JsonConvert.SerializeObject(data);

在这段代码中,我们使用 DataGridView 中每一列的唯一的 HeaderText 作为字典中的键。如果 HeaderText 不唯一,可以使用其他标识符来作为键。


DataGridView数据转为XML格式

首先,我们可以使用C#中的XmlSerializer类来将DataGridView中的数据转为XML格式的字符串。

第一步,创建一个XmlSerializer对象,并指定要序列化的数据类型。

XmlSerializer serializer = new XmlSerializer(typeof(DataGridViewRow));

第二步,遍历DataGridView的每一行,将每一行数据序列化为XML格式的字符串,并将它们拼接起来。

StringBuilder sb = new StringBuilder();
foreach (DataGridViewRow row in dataGridView1.Rows)
{
   
   
    StringWriter writer = new StringWriter();
    serializer.Serialize(writer, row);
    sb.AppendLine(writer.ToString());
}

第三步,将拼接好的字符串作为最终的XML格式的字符串输出。

string xmlString = sb.ToString();
Console.WriteLine(xmlString);

这样,就可以将DataGridView中的数据转为XML格式的字符串了。

相关文章
|
5月前
|
JSON API 数据格式
淘宝拍立淘按图搜索API系列,json数据返回
淘宝拍立淘按图搜索API系列通过图像识别技术实现商品搜索功能,调用后返回的JSON数据包含商品标题、图片链接、价格、销量、相似度评分等核心字段,支持分页和详细商品信息展示。以下是该API接口返回的JSON数据示例及详细解析:
|
5月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
5月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
5月前
|
JSON 中间件 Java
【GoGin】(3)Gin的数据渲染和中间件的使用:数据渲染、返回JSON、浅.JSON()源码、中间件、Next()方法
我们在正常注册中间件时,会打断原有的运行流程,但是你可以在中间件函数内部添加Next()方法,这样可以让原有的运行流程继续执行,当原有的运行流程结束后再回来执行中间件内部的内容。​ c.Writer.WriteHeaderNow()还会写入文本流中。可以看到使用next后,正常执行流程中并没有获得到中间件设置的值。接口还提供了一个可以修改ContentType的方法。判断了传入的状态码是否符合正确的状态码,并返回。在内部封装时,只是标注了不同的render类型。再看一下其他返回的类型;
284 3
|
5月前
|
JSON Java Go
【GoGin】(2)数据解析和绑定:结构体分析,包括JSON解析、form解析、URL解析,区分绑定的Bind方法
bind或bindXXX函数(后文中我们统一都叫bind函数)的作用就是将,以方便后续业务逻辑的处理。
354 3
|
6月前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
|
6月前
|
JSON 自然语言处理 监控
淘宝关键词搜索与商品详情API接口(JSON数据返回)
通过商品ID(num_iid)获取商品全量信息,包括SKU规格、库存、促销活动、卖家信息、详情页HTML等。
|
6月前
|
XML 前端开发 C#
C#编程实践:解析HTML文档并执行元素匹配
通过上述步骤,可以在C#中有效地解析HTML文档并执行元素匹配。HtmlAgilityPack提供了一个强大而灵活的工具集,可以处理各种HTML解析任务。
318 19
|
7月前
|
监控 算法 C#
C#与Halcon联合编程实现鼠标控制图像缩放、拖动及ROI绘制
C#与Halcon联合编程实现鼠标控制图像缩放、拖动及ROI绘制
1277 0
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
340 3