Newtonsoft.Json序列化数据,移除某个属性,返回自定义数据

源返回json:

{
  "Result": {
    "AccName": "New 2018-05-08 11:22:44",
    "BeginTime": "1970-01-01T00:00:00",
    "EndTime": null,
    "MaxDrawDownRate": 0.0,
    "AccountCorporation": "",
    "YearProfitPrecentage": 0.0,
    "CreateUserName": "MatrixUser",
    "HasDataType": "期货,股票",
    "DataTypes": [
      {
        "Value": "8",
        "Text": "期货",
        "Name": null
      },
      {
        "Value": "1",
        "Text": "股票",
        "Name": null
      }
    ],
    "SumAmount": 2000000.0,
    "CapitaleAmount": 2000000.0,
    "Cash": 0.0
  },
  "Head": {
    "Message": "获取成功",
    "Code": "200",
    "CallTime": "2018-05-24 15:19:04"
  }
}

现在前端不需要DataTypes这个节点数据,需要在后台移除掉,将此json作为变量json传入方法JObject.Parse(json)
处理代码:

//移除某个属性,以不返回该数据
JObject jobject = JObject.Parse(json);           
JObject tokenselect = jobject.SelectToken("Result") as JObject;
tokenselect.Remove("DataTypes");

完整的代码

using Newtonsoft.Json.Linq;

public ActionResult Detail(int id)
    //待处理的josn字符串
	string json="";
    //移除某个属性,以不返回该数据
    JObject jobject = JObject.Parse(json);           
    JObject tokenselect = jobject.SelectToken("Result") as JObject;
    tokenselect.Remove("DataTypes");
    return Json(tokenselect);
}

var skuListJson=[{"ProductCategorySysNo":"467011276116070400","MalfunctionsSysNo":"467011100731248640","PropertyValueSysNos":"467011331313111040,467011331510243328,467011332495904768","SysNo":"467011332256829440","Price":2500.00},{"ProductCategorySysNo":"467011276116070400","MalfunctionsSysNo":"467011100731248640","PropertyValueSysNos":"467011331313111040,467011331510243328,467011331845787648","SysNo":"467011331208253440","Price":2000.00},{"ProductCategorySysNo":"467011276116070400","MalfunctionsSysNo":"467011095232516096","PropertyValueSysNos":"467011326095396864,467011326493855744,467011330340032512","SysNo":"467011330189037568","Price":0.00}];	
	
Newtonsoft.Json.Linq移除對象中不需要的屬性或字段
JArray對應的是集合,JObject對應一條記錄
//list是一個C#List<T>對象泛型集合
JArray jArray = JArray.FromObject(list);
//方式二:這樣也行
//JArray jArray =JArray.Parse(skuListJson);
foreach (JObject item in jArray)
{              
    //移除屬性SysNo、ProductCategorySysNo
	item.Remove("SysNo");
	item.Remove("ProductCategorySysNo");
}         
//最後在將jArray序列化為json字符串
string skuListJson = JsonConvert.SerializeObject(jArray);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 VB.NET 中使用 Newtonsoft.Json 序列化结构体的过程与序列化类的过程类似。你可以使用 `JsonConvert.SerializeObject` 方法将结构体对象转换为 JSON 字符串,以及使用 `JsonConvert.DeserializeObject` 方法将 JSON 字符串转换回结构体对象。 以下是一个示例代码,演示如何使用 Newtonsoft.Json 序列化结构体: ```vb Imports Newtonsoft.Json ' 定义一个结构体 Public Structure Person Public Name As String Public Age As Integer End Structure Sub Main() ' 创建一个结构体对象 Dim person As New Person With { .Name = "John", .Age = 25 } ' 序列化结构体为 JSON 字符串 Dim json As String = JsonConvert.SerializeObject(person) ' 输出序列化后的 JSON 字符串 Console.WriteLine(json) ' 反序列化 JSON 字符串为结构体对象 Dim deserializedPerson As Person = JsonConvert.DeserializeObject(Of Person)(json) ' 输出反序列化后的结构体对象的属性值 Console.WriteLine(deserializedPerson.Name) Console.WriteLine(deserializedPerson.Age) End Sub ``` 在这个示例中,我们首先定义了一个名为 `Person` 的结构体,其中包含了 `Name` 和 `Age` 两个属性。 然后,我们创建了一个 `Person` 结构体对象,并设置了其属性值。 接下来,使用 `JsonConvert.SerializeObject` 方法将结构体对象序列化JSON 字符串,并将结果存储在 `json` 变量中。 然后,我们输出序列化后的 JSON 字符串。 最后,使用 `JsonConvert.DeserializeObject` 方法将 JSON 字符串反序列化为 `Person` 结构体对象,并将结果存储在 `deserializedPerson` 变量中。 最后,我们输出反序列化后的结构体对象的属性值。 确保在项目中引用了 Newtonsoft.Json 库,并在代码文件中导入了命名空间 `Newtonsoft.Json`。 希望这个示例能够帮助你在 VB.NET 中使用 Newtonsoft.Json 序列化结构体。如果你还有其他问题,请随时提问!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王焜棟琦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值