Как разобрать JSON с помощью C#?

У меня есть следующий код:

var user = (Dictionary<string, object>)serializer.DeserializeObject(responsecontent);

Входные данные в responsecontent являются JSON, но они неправильно разбираются в объект. Как мне правильно десериализовать его?

Комментарии к вопросу (9)

Я предполагаю, что вы не используете Json.NET (NuGet-пакет Newtonsoft.Json). Если это так, то вам следует попробовать.

Он имеет следующие возможности:

  1. LINQ to JSON
  2. JsonSerializer для быстрого преобразования объектов .NET в JSON и обратно.
  3. Json.NET может по желанию создавать хорошо отформатированный JSON с отступами для отладки или отображения.
  4. Атрибуты JsonIgnore и JsonProperty могут быть добавлены к классу, чтобы настроить способ сериализации класса.
  5. Возможность преобразования JSON в XML и обратно
  6. Поддержка нескольких платформ: .NET, Silverlight и Compact Framework

Посмотрите на пример ниже. В этом примере класс JsonConvert используется для преобразования объекта в JSON и обратно. Для этого в нем есть два статических метода. Это SerializeObject(Object obj) и DeserializeObject(String json):

Product product = new Product();
product.Name = "Apple";
product.Expiry = new DateTime(2008, 12, 28);
product.Price = 3.99M;
product.Sizes = new string[] { "Small", "Medium", "Large" };

string json = JsonConvert.SerializeObject(product);
//{
//  "Name": "Apple",
//  "Expiry": "2008-12-28T00:00:00",
//  "Price": 3.99,
//  "Sizes": [
//    "Small",
//    "Medium",
//    "Large"
//  ]
//}

Product deserializedProduct = JsonConvert.DeserializeObject(json);
Комментарии (12)

Как ответили здесь - десериализовать JSON в C и динамический объект#?

Это'ы довольно просто с помощью Json.NET:

dynamic stuff = JsonConvert.DeserializeObject("{ 'Name': 'Jon Smith', 'Address': { 'City': 'New York', 'State': 'NY' }, 'Age': 42 }");

string name = stuff.Name;
string address = stuff.Address.City;

Или используя Newtonsoft.В JSON.В LINQ :

dynamic stuff = JObject.Parse("{ 'Name': 'Jon Smith', 'Address': { 'City': 'New York', 'State': 'NY' }, 'Age': 42 }");

string name = stuff.Name;
string address = stuff.Address.City;
Комментарии (4)

Вот несколько вариантов без используя сторонние библиотеки:

// For that you will need to add reference to System.Runtime.Serialization
var jsonReader = JsonReaderWriterFactory.CreateJsonReader(Encoding.UTF8.GetBytes(@"{ ""Name"": ""Jon Smith"", ""Address"": { ""City"": ""New York"", ""State"": ""NY"" }, ""Age"": 42 }"), new System.Xml.XmlDictionaryReaderQuotas());

// For that you will need to add reference to System.Xml and System.Xml.Linq
var root = XElement.Load(jsonReader);
Console.WriteLine(root.XPathSelectElement("//Name").Value);
Console.WriteLine(root.XPathSelectElement("//Address/State").Value);

// For that you will need to add reference to System.Web.Helpers
dynamic json = System.Web.Helpers.Json.Decode(@"{ ""Name"": ""Jon Smith"", ""Address"": { ""City"": ""New York"", ""State"": ""NY"" }, ""Age"": 42 }");
Console.WriteLine(json.Name);
Console.WriteLine(json.Address.State);

См. ссылку для получения дополнительной информации о системе.Веб.Хелперов.В JSON]1.

Обновление: в наше время самый простой способ получить в Интернете.Помощники-это использовать пакет NuGet.


Если вы Don'т заботиться о более ранних версиях Windows вы можете использовать классы окна.Данных.Формат JSON` пространства имен:

// minimum supported version: Win 8
JsonObject root = Windows.Data.Json.JsonValue.Parse(jsonString).GetObject();
Console.WriteLine(root["Name"].GetString());
Console.WriteLine(root["Address"].GetObject()["State"].GetString());
Комментарии (11)

Если .NET 4 доступен для вас, посмотрите: http://visitmix.com/writings/the-rise-of-json (archive.org)

Вот фрагмент с этого сайта:

WebClient webClient = new WebClient();
dynamic result = JsonValue.Parse(webClient.DownloadString("https://api.foursquare.com/v2/users/self?oauth_token=XXXXXXX"));
Console.WriteLine(result.response.user.firstName);

Этот последний Console.WriteLine довольно милый...

Комментарии (3)

Еще один уроженец решения этой проблемы, которая не'т требует каких-либо 3-й партии библиотеки, но ссылка на системы.Веб.Расширения - это класс javascriptserializer. Это не новая, но очень неизвестной причине-в особенности там с 3.5.

using System.Web.Script.Serialization;

..

JavaScriptSerializer serializer = new JavaScriptSerializer();
objectString = serializer.Serialize(new MyObject());

и обратно

MyObject o = serializer.Deserialize(objectString)
Комментарии (3)

Вы также можете взглянуть на DataContractJsonSerializer

Комментарии (2)

Системы.В JSON работает сейчас...

Установить NuGet https://www.nuget.org/packages/System.Json

PM> Install-Package System.Json -Version 4.5.0

Образец:

// PM>Install-Package System.Json -Version 4.5.0

using System;
using System.Json;

namespace NetCoreTestConsoleApp
{
    class Program
    {
        static void Main(string[] args)
        {
            // Note that JSON keys are case sensitive, a is not same as A.

            // JSON Sample
            string jsonString = "{\"a\": 1,\"b\": \"string value\",\"c\":[{\"Value\": 1}, {\"Value\": 2,\"SubObject\":[{\"SubValue\":3}]}]}";

            // You can use the following line in a beautifier/JSON formatted for better view
            // {"a": 1,"b": "string value","c":[{"Value": 1}, {"Value": 2,"SubObject":[{"SubValue":3}]}]}

            /* Formatted jsonString for viewing purposes:
            {
               "a":1,
               "b":"string value",
               "c":[
                  {
                     "Value":1
                  },
                  {
                     "Value":2,
                     "SubObject":[
                        {
                           "SubValue":3
                        }
                     ]
                  }
               ]
            }
            */

            // Verify your JSON if you get any errors here
            JsonValue json = JsonValue.Parse(jsonString);

            // int test
            if (json.ContainsKey("a"))
            {
                int a = json["a"]; // type already set to int
                Console.WriteLine("json[\"a\"]" + " = " + a);
            }

            // string test
            if (json.ContainsKey("b"))
            {
                string b = json["b"];  // type already set to string
                Console.WriteLine("json[\"b\"]" + " = " + b);
            }

            // object array test
            if (json.ContainsKey("c") && json["c"].JsonType == JsonType.Array)
            {
                // foreach loop test
                foreach (JsonValue j in json["c"])
                {
                    Console.WriteLine("j[\"Value\"]" + " = " + j["Value"].ToString());
                }

                // multi level key test
                Console.WriteLine("json[\"c\"][0][\"Value\"]" + " = " + json["c"][0]["Value"].ToString());
                Console.WriteLine("json[\"c\"][0][\"Value\"]" + " = " + json["c"][1]["Value"].ToString());
                Console.WriteLine("json[\"c\"][1][\"SubObject\"][0][\"SubValue\"]" + " = " + json["c"][1]["SubObject"][0]["SubValue"].ToString());
            }

            Console.WriteLine();
            Console.Write("Press any key to exit.");
            Console.ReadKey();
        }
    }
}
Комментарии (0)

Используйте этот инструмент для создания класса в JSON:

http://json2csharp.com/

И затем использовать этот класс для десериализации JSON в ваш. Пример:

public class Account
{
    public string Email { get; set; }
    public bool Active { get; set; }
    public DateTime CreatedDate { get; set; }
    public IList Roles { get; set; }
}

string json = @"{
  'Email': 'james@example.com',
  'Active': true,
  'CreatedDate': '2013-01-20T00:00:00Z',
  'Roles': [
    'User',
    'Admin'
  ]
}";

Account account = JsonConvert.DeserializeObject(json);

Console.WriteLine(account.Email);
// james@example.com

Ссылки: https://forums.asp.net/t/1992996.aspx?Nested+в формате JSON+десериализации+в+с+объект+и+через+что+объект https://www.newtonsoft.com/json/help/html/DeserializeObject.htm

Комментарии (0)

Попробуйте следующий код:

HttpWebRequest request = (HttpWebRequest)WebRequest.Create("URL");
JArray array = new JArray();
using (var twitpicResponse = (HttpWebResponse)request.GetResponse())
using (var reader = new StreamReader(twitpicResponse.GetResponseStream()))
{
    JavaScriptSerializer js = new JavaScriptSerializer();
    var objText = reader.ReadToEnd();

    JObject joResponse = JObject.Parse(objText);
    JObject result = (JObject)joResponse["result"];
    array = (JArray)result["Detail"];
    string statu = array[0]["dlrStat"].ToString();
}
Комментарии (1)

Следующие От в MSDN место должно я думаю помочь обеспечить некоторую функциональность за то, что вы ищете. Пожалуйста, обратите внимание, указан для Windows 8. Один из таких примеров с сайта приведен ниже.

JsonValue jsonValue = JsonValue.Parse("{\"Width\": 800, \"Height\": 600, \"Title\": \"View from 15th Floor\", \"IDs\": [116, 943, 234, 38793]}");
double width = jsonValue.GetObject().GetNamedNumber("Width");
double height = jsonValue.GetObject().GetNamedNumber("Height");
string title = jsonValue.GetObject().GetNamedString("Title");
JsonArray ids = jsonValue.GetObject().GetNamedArray("IDs");

Он использует окна.Данных.В JSON пространство имен.

Комментарии (3)

Я думаю, самый лучший ответ, который я'видел был @MD_Sayem_Ahmed.

Ваш вопрос "Как я могу распарсить JSON с помощью C#", но похоже, что вы хотите декодировать формат JSON. Если вы желаете, чтобы расшифровать его, Ахмед'ы ответ-это хорошо.

Если вы пытаетесь сделать это в веб ASP.NET API-интерфейс, самый простой способ-создать объект передачи данных, который содержит данные, которые вы хотите назначить:

public class MyDto{
    public string Name{get; set;}
    public string Value{get; set;}
}

Вы просто добавить заголовок приложения/JSON для вашего запроса (если вы не с помощью Fiddler, например). Затем вы можете использовать это в веб ASP.NET API, как указано ниже:

//controller method -- assuming you want to post and return data
public MyDto Post([FromBody] MyDto myDto){
   MyDto someDto = myDto;
   /*ASP.NET automatically converts the data for you into this object 
    if you post a json object as follows:
{
    "Name": "SomeName",
      "Value": "SomeValue"
}
*/
   //do some stuff
}

Это помогло мне много, когда я работаю на моем веб-API и сделал мою жизнь супер просто.

Комментарии (0)
         string json = @"{
            'Name': 'Wide Web',
            'Url': 'www.wideweb.com.br'}";

        JavaScriptSerializer jsonSerializer = new JavaScriptSerializer();
        dynamic j = jsonSerializer.Deserialize(json);
        string name = j["Name"].ToString();
        string url = j["Url"].ToString();
Комментарии (0)

Системы.Текст.В JSON

.чистая ядра 3.0 поставляется с системой .Текст.Формат JSON встроенный это значит, что теперь вы можете десериализации/сериализации в JSON без использование сторонней библиотеки.

Чтобы сериализовать свой класс(ы) в JSON-строку:

var json = JsonSerializer.Serialize(order);

Чтобы десериализовать JSON в строго типизированный класс:

var order = JsonSerializer.Deserialize(json);

Так что если у вас есть класс, как показано ниже:

public class Order
{
    public int Id { get; set; }
    public string OrderNumber { get; set; }
    public decimal Balance { get; set; }
    public DateTime Opened { get; set; }
}

var json = JsonSerializer.Serialize(order);
// creates JSON ==>
{
    "id": 123456,
    "orderNumber": "ABC-123-456",
    "balance": 9876.54,
    "opened": "2019-10-21T23:47:16.85",
};

var order = JsonSerializer.Deserialize(json);
// ==> creates the above class

Одна вещь отметить состоит в том, что система.Текст.Формат JSON**не** автоматически обрабатыватьверблюжьего` в JSON свойства *когда вы используете свой собственный код** (тем не менее, когда с использованием MVC/веб-API запросов и связыватель модели).

Так что если у вас есть в формате JSON, как показано ниже, и "порядок", как и выше, то он не будет десериализовать в класс.

var json = @"{
    ""id"": 123456,
    ""orderNumber"": ""ABC-123-456"",
    ""balance"": 9876.54,
    ""opened"": ""2019-10-21T23:47:16.8513874+01:00"",
}";

Для устранения этой ошибки необходимо пройти JsonSerializerOptions в качестве параметра (к сожалению, это's не возможно, чтобы настроить это приложение в ширину).

JsonSerializerOptions options = new JsonSerializerOptions
{        
    PropertyNamingPolicy = JsonNamingPolicy.CamelCase,  // set camelCase       
    WriteIndented = true   // write pretty json
};

// serialize using options
var json = JsonSerializer.Serialize(order, options);
// deserialize using options
var order = JsonSerializer.Deserialize(json, options);

Системы.Текст.Формат JSON также доступна для .NET и .Объем стандартный в качестве ню-получить пакет система.Текст.В JSON

Комментарии (0)
var result = controller.ActioName(objParams);
IDictionary data = (IDictionary)new System.Web.Routing.RouteValueDictionary(result.Data);
Assert.AreEqual("Table already exists.", data["Message"]);
Комментарии (2)
 using (var ms = new MemoryStream(Encoding.Unicode.GetBytes(user)))
 {
    // Deserialization from JSON  
    DataContractJsonSerializer deserializer = new DataContractJsonSerializer(typeof(UserListing))
    DataContractJsonSerializer(typeof(UserListing));
    UserListing response = (UserListing)deserializer.ReadObject(ms);

 }

 public class UserListing
 {
    public List users { get; set; }      
 }

 public class UserList
 {
    public string FirstName { get; set; }       
    public string LastName { get; set; } 
 }
Комментарии (0)