C#操作 JSON方法匯總
RestAPI中, 經(jīng)常需要操作json字符串, 需要把json字符串"反序列化"成一個對象, 也需要把一個對象"序列化"成一字符串。
C# 操作json, 比較簡單。 本文介紹幾種方法
步驟
Json 字符串 反序列化成對象 共需要2步:
第一步:建立相應(yīng)的實體類
第二步: 調(diào)用方法把Json字符串"反序列化"成對象
了解json的語法
首先要了解json的語法,這樣才能知道怎么創(chuàng)建實體類.
Json 的語法很簡單, 就四條
數(shù)據(jù)在名稱/值對中
數(shù)據(jù)由逗號分隔
花括號保存對象
方括號保存數(shù)組
創(chuàng)建實體類的例子
{"FirstName":"小坦克","LastName":"Tank","Age":30}
相應(yīng)的實體類可以為
public class Person
{
public String FirstName
{ get; set; }
public String LastName
{ get; set; }
public int Age
{ get; set; }
}
自動生成JSON的實體類
一個復(fù)雜的實體類,我們自己去寫的話,可能需要1個小時以上。 那有沒有工具能直接生成實體類呢,這樣能方便太多了。 當(dāng)然有
http://jsonclassgenerator.codeplex.com/ ----開源的winform工具。
使用第三方工具 Newtonsoft.Json.dll
優(yōu)點: 使用非常方便. 看個例子就知道怎么用了
下載地址 http://www.dbjr.com.cn/dll/Newtonsoft.Json.dll.html
代碼示例:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Newtonsoft.Json;
namespace JsonDemo
{
class Program
{
static void Main(string[] args)
{
string personJson = "{ 'FirstName': '小坦克','LastName':'Tank xiao', 'Age':'30', 'Books':[{'BookName':'c#', 'Price':'29.9'},{'BookName':'Mac編程', 'Price':'39.9'}]}";
string allMoveJson = @"[{ 'FirstName': '小坦克','LastName':'Tank xiao', 'Age':'30', 'Books':[{'BookName':'c#', 'Price':'29.9'},{'BookName':'Mac編程', 'Price':'39.9'}]},{
'FirstName': '小坦克2','LastName':'Tank xiao2', 'Age':'40', 'Books':[{'BookName':'c#', 'Price':'29.9'},{'BookName':'Mac編程', 'Price':'39.9'}]}]";
// 反序列化 單個對象
Person oneMovie = JsonConvert.DeserializeObject<Person>(personJson);
// 反序列化 對象集合
List<Person> allMovie = JsonConvert.DeserializeObject<List<Person>>(allMoveJson);
Console.WriteLine(oneMovie.FirstName);
Console.WriteLine(allMovie[1].FirstName);
// 序列化
string afterJson = JsonConvert.SerializeObject(allMovie);
}
}
public class Person
{
public String FirstName
{ get; set; }
public String LastName
{ get; set; }
public int Age
{ get; set; }
public List<Book> Books
{ get; set; }
}
public class Book
{
public string BookName
{ get; set; }
public string Price
{ get; set; }
}
}
最后我們來看個實例
using System;
using System.Collections.Generic;
using System.Text;
using Newtonsoft.Json;
namespace TestJson
{
class Program
{
static void Main(string[] args)
{
string json = "{\"a\":\"sadsad\",\"c\":{\"d\":\"adad\"}}";
//CCC ccc = new CCC();
//ccc.d = "adad";
//AAA aaa = new AAA();
//aaa.a = "sadsad";
//aaa.b = "dfgdg";
//aaa.c = ccc;
AAA aaa = new AAA();
aaa= JavaScriptConvert.DeserializeObject<AAA>(json);
// string json = JavaScriptConvert.SerializeObject(aaa);
// Console.WriteLine(json);
Console.Read();
}
}
public class AAA {
private string m_a;
public string a
{
get { return m_a; }
set { m_a = value; }
}
private string m_b;
public string b
{
get { return m_b; }
set { m_b = value; }
}
private CCC m_c;
public CCC c
{
get { return m_c; }
set { m_c = value; }
}
}
public class CCC
{
private string m_d;
public string d
{
get { return m_d; }
set { m_d = value; }
}
}
}
- C#中把Datatable轉(zhuǎn)換為Json的5個代碼實例
- C#中的DataSet、string、DataTable、對象轉(zhuǎn)換成Json的實現(xiàn)代碼
- C#解析JSON實例
- C#實現(xiàn)Json轉(zhuǎn)Unicode的方法
- C#實現(xiàn)對Json字符串處理實例
- C#處理Json字符串實例分析
- C#實現(xiàn)將json轉(zhuǎn)換為DataTable的方法
- C#實現(xiàn)的json序列化和反序列化代碼實例
- C#實現(xiàn)json格式轉(zhuǎn)換成對象并更換key的方法
- C#實現(xiàn)將類的內(nèi)容寫成JSON格式字符串的方法
- C#中Json字符串的各種應(yīng)用類實例講解
- C#中使用JSON.NET實現(xiàn)JSON、XML相互轉(zhuǎn)換
- C# JSON格式化轉(zhuǎn)換輔助類 ConvertJson
相關(guān)文章
C#使用AutoUpdater.NET實現(xiàn)程序自動更新
開發(fā)桌面應(yīng)用程序的時候,經(jīng)常會因為新增功能需求或修復(fù)已知問題,要求客戶更新應(yīng)用程序,在.Net體系中采用?AutoUpdater.NET?組件可以非常便捷的實現(xiàn)這一功能,需要的朋友可以參考下2024-02-02
C#使用Socket實現(xiàn)發(fā)送和接收圖片的方法
這篇文章主要介紹了C#使用Socket實現(xiàn)發(fā)送和接收圖片的方法,涉及C#操作socket發(fā)送與接收文件的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-04-04
C#實現(xiàn)將HTML網(wǎng)頁或HTML字符串轉(zhuǎn)換為PDF
將HTML轉(zhuǎn)換為PDF可實現(xiàn)格式保留、可靠打印、文檔歸檔等多種用途,滿足不同領(lǐng)域和情境下的需求,所以本文就來介紹一下如何使用C#實現(xiàn)將HTML網(wǎng)頁或HTML字符串轉(zhuǎn)換為PDF,有需要的可以參考下2024-01-01
c# 免費組件html轉(zhuǎn)pdf的實現(xiàn)過程
這篇文章主要介紹了c# 免費組件html轉(zhuǎn)pdf的實現(xiàn)過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06
Windows 8 Metro用C#連接SQLite及創(chuàng)建數(shù)據(jù)庫,數(shù)據(jù)表的增刪改查的實現(xiàn)
本篇文章小編為大家介紹,Windows 8 Metro用C#連接SQLite及創(chuàng)建數(shù)據(jù)庫,數(shù)據(jù)表的增刪改查的實現(xiàn)。需要的朋友參考下2013-04-04

