weixin_40187983 2019-07-01 10:18 采纳率: 100%
浏览 619
已采纳

vb.net 将json还原成datatable-在线等

以下的代码是将datatable转成json的方法

我想再将json转回成原本的datatable请问要如何现呢? 感谢

图片说明

Public Function DataTableToJson(ByVal dt As DataTable) As String
Dim jsonBuilder As StringBuilder = New StringBuilder()
For i As Integer = 0 To dt.Rows.Count - 1
jsonBuilder.Append("{")

        For j As Integer = 0 To dt.Columns.Count - 1
            jsonBuilder.Append("""")
            jsonBuilder.Append(dt.Columns(j).ColumnName)
            jsonBuilder.Append(""":""")
            jsonBuilder.Append(dt.Rows(i)(j).ToString())
            jsonBuilder.Append(""",")
        Next

        If dt.Columns.Count > 0 Then
            jsonBuilder.Remove(jsonBuilder.Length - 1, 1)
        End If

        jsonBuilder.Append("},")
    Next

    If dt.Rows.Count > 0 Then
        jsonBuilder.Remove(jsonBuilder.Length - 1, 1)
    End If

    Return jsonBuilder.ToString()
End Function
  • 写回答

1条回答 默认 最新

  • threenewbee 2019-07-01 10:25
    关注

    json转换成datatable往往没有通用的代码,这是因为json是层次型的数据。列表是它的一个特例。
    因此datatable的数据肯定可以用json来描述,而json的数据如果是层次的,就很难用二维的表格来描述,比如这样一个js
    {
    country :
    {
    name: "china"
    province:
    {
    name : "shandong"
    city: { name: "jinan" }
    }
    }
    }
    它是一个多层的层次关系,就不太好用dt表示。

    所以我建议你将json反序列化成对象
    然后根据你需要的,将其中的某个List类型的对象,再转换为datatable

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 Attributeerror:super object has no attribute '__sklearn_tags__'_'
  • ¥15 逆置单链表输出不完整
  • ¥15 宇视vms-B200-A16@R启动不了,如下图所示,在软件工具搜不到,如何解决?(操作系统-linux)
  • ¥500 寻找一名电子工程师完成pcb主板设计(拒绝AI生成式答案)
  • ¥15 关于#mysql#的问题:UNION ALL(相关搜索:sql语句)
  • ¥15 matlab二位可视化能否针对不同数值范围分开分级?
  • ¥15 已经创建了模拟器但是不能用来运行app 怎么办😭自己搞两天了
  • ¥15 关于#极限编程#的问题,请各位专家解答!
  • ¥20 win11账户锁定时间设为0无法登录
  • ¥45 C#学生成绩管理系统