C#,VB.NET从JSON数据里提取数组中的对象节点值

VB.NET中,若要从 JSON 数据里提取Data.DataList数组中的CategoryId,并将其转换为VB.NET数组,可借助Json.NET(Newtonsoft.Json)库来实现。下面为你详细介绍具体的实现步骤和代码示例:

一、实现 JSON 到数组的转换

方法 1:通过 JObject 解析(灵活通用)
vbnet 复制代码
Imports Newtonsoft.Json
Imports Newtonsoft.Json.Linq

Public Function ExtractCategoryIds(jsonText As String) As Long()
    Try
        ' 解析JSON根对象
        Dim jsonObj As JObject = JObject.Parse(jsonText)
        
        ' 获取DataList数组
        Dim dataList As JArray = jsonObj?("Data")?("DataList") as JArray
        If dataList Is Nothing Then
            Return New Long(-1) {}  ' 返回空数组
        End If
        
        ' 提取CategoryId并转换为数组
        Return dataList
            .Select(Function(item) item?("CategoryId")?.Value(Of Long)())
            .Where(Function(id) id.HasValue)
            .Select(Function(id) id.Value)
            .ToArray()
    Catch ex As Exception
        Console.WriteLine("JSON解析错误: " & ex.Message)
        Return New Long(-1) {}  ' 出错时返回空数组
    End Try
End Function

方法 2:反序列化为强类型对象(类型安全)

vbnet 复制代码
Imports Newtonsoft.Json

' 定义数据模型
Public Class RootObject
    Public Property Code As Integer
    Public Property Data As DataObject
End Class

Public Class DataObject
    Public Property TotalCount As Integer
    Public Property PageIndex As Integer
    Public Property PageSize As Integer
    Public Property DataList As List(Of CategoryItem)
End Class

Public Class CategoryItem
    Public Property CategoryId As Long
End Class

' 转换方法
Public Function ExtractCategoryIdsWithModel(jsonText As String) As Long()
    Try
        ' 反序列化为强类型对象
        Dim root As RootObject = JsonConvert.DeserializeObject(Of RootObject)(jsonText)
        
        ' 提取CategoryId数组
        If root?.Data?.DataList Is Nothing Then
            Return New Long(-1) {}
        End If
        
        Return root.Data.DataList
            .Select(Function(item) item.CategoryId)
            .ToArray()
    Catch ex As Exception
        Console.WriteLine("JSON反序列化错误: " & ex.Message)
        Return New Long(-1) {}
    End Try
End Function

二、使用示例

vbnet 复制代码
Sub Main()
    Dim jsonText As String = "{""Code"":200,""Data"":{""TotalCount"":14,""PageIndex"":1,""PageSize"":100,""DataList"":[{""CategoryId"":271},{""CategoryId"":272}]}}"
    
    ' 方法1:动态解析
    Dim categoryIds1 As Long() = ExtractCategoryIds(jsonText)
    
    ' 方法2:强类型解析
    Dim categoryIds2 As Long() = ExtractCategoryIdsWithModel(jsonText)
    
    ' 输出结果
    Console.WriteLine("提取的CategoryId数组:")
    For Each id In categoryIds1
        Console.WriteLine(id)  ' 输出: 271, 272
    Next
End Sub

三、关键要点说明

  1. 空值处理

    • 运用?.操作符来避免出现NullReferenceException
    • 对可能为空的数组进行检查,防止程序崩溃。
  2. 类型转换

    • 采用Value(Of Long)()方法将 JSON 值转换为 Long 类型。
    • 借助Where(Function(id) id.HasValue)过滤掉无效的值。
  3. 异常处理

    • 捕获JsonReaderExceptionJsonSerializationException,增强程序的健壮性。
    • 出错时返回空数组,而非Nothing,减少上层代码的判断逻辑。

四、扩展功能

1. 处理嵌套路径(通用方法)

vb

vbnet 复制代码
Public Function ExtractValuesByPath(jsonText As String, path As String) As Long()
    Try
        Dim jsonToken As JToken = JToken.Parse(jsonText)
        Dim tokens As IEnumerable(Of JToken) = jsonToken.SelectTokens(path)
        
        Return tokens
            .Select(Function(token) token.Value(Of Long)())
            .ToArray()
    Catch ex As Exception
        Console.WriteLine($"提取路径 {path} 出错: {ex.Message}")
        Return New Long(-1) {}
    End Try
End Function

' 使用示例
Dim categoryIds As Long() = ExtractValuesByPath(jsonText, "$.Data.DataList[*].CategoryId")
2. 异步解析大 JSON 文件
vbnet 复制代码
Public Async Function ExtractCategoryIdsAsync(jsonText As String) As Task(Of Long())
    Try
        Using reader As New StringReader(jsonText)
            Using jsonReader As New JsonTextReader(reader)
                Dim serializer As JsonSerializer = New JsonSerializer()
                Dim root As RootObject = Await Task.Run(Function() 
                    serializer.Deserialize(Of RootObject)(jsonReader)
                End Function)
                
                Return root?.Data?.DataList?
                    .Select(Function(item) item.CategoryId)
                    .ToArray() ?? New Long(-1) {}
            End Using
        End Using
    Catch ex As Exception
        Console.WriteLine("异步解析错误: " & ex.Message)
        Return New Long(-1) {}
    End Try
End Function

五、性能考量

  • 小 JSON:推荐使用强类型反序列化(方法 2),这样能提高代码的可读性和类型安全性。
  • 大 JSON :建议采用JsonTextReader进行流式解析,以降低内存的占用。
  • 动态路径 :可使用SelectTokens方法来处理复杂的 JSON 结构。

通过上述方法,你可以在VB.NET中高效、安全地从 JSON 数据里提取所需的数组。

在不使用第三方库的情况下,如何实现JSON到数组的转换?

提供一些关于JSON和数组操作的VB.NET最佳实践。

除了Json.NET库,还有哪些常用的JSON库可用于VB.NET

相关推荐
獨枭1 小时前
.NET Framework 依赖版本冲突解决方案:从现象到本质
.net
ID_180079054732 小时前
闲鱼商品详情API接口基础架构解析
json
故事不长丨2 小时前
C#进制转换:从基础原理到实战应用
开发语言·c#·进制转换·16进制·2进制·10进制
liulilittle2 小时前
VEthernet 框架实现 tun2socks 的技术原理
网络·windows·c#·信息与通信·通信
云草桑3 小时前
.net AI API应用 客户发的信息提取对接上下游系统报价
ai·c#·.net·semantickernel·sk
故事不长丨4 小时前
C#File文件操作全解析:从基础用法到异常处理
服务器·开发语言·visualstudio·c#·文件操作·io流·file
wtsolutions5 小时前
Sheet-to-Doc数据格式支持:JSON/JSONL/CSV全解析
json
工程师0075 小时前
C# 动态编程(基于 dynamic 类型)
开发语言·c#·dynamic·动态编程
用户298698530145 小时前
C#: 在Word文档中添加或移除可编辑区域
后端·c#
切糕师学AI5 小时前
win下,当.NET控制台进程被强制终止(如关闭控制台、任务管理器结束进程等)时,如何优雅地清理数据
.net·控制台·进程