Member 13621621 Ответов: 2

Ошибки, когда JSON возвращает нулевое значение


Поэтому я недавно снова начал кодировать, и до сих пор этот форум был мне более чем полезен. В любом случае, я работаю над простой формой, которая захватывает строку JSON из веб-API и десериализует ее в поле списка. Однако любая строка, возвращающая любое нулевое значение, ошибается. Я знаю, что это простая проблема, но не могу ни за что на свете понять, как заставить его игнорировать нулевые значения! Заранее спасибо!

Что я уже пробовал:

Это моя первая остановка за помощью

Thomas Daniels

Можете ли вы поделиться своим кодом (и примером JSON, чтобы мы могли его протестировать)?

Richard MacCutchan

Почему вы разместили свой код в качестве решения? Люди будут думать, что этот вопрос решен, и игнорировать его. Переместите его в вопрос и удалите его, если вам нужна помощь.

2 Ответов

Рейтинг:
2

Member 13621621

код формы

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Newtonsoft.Json;


namespace WhitePagesTool
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {

        }
        #region UI events
        private void cmdDeserialize_Click(object sender, EventArgs e)
        {
            deserialiseJSON(txtInput.Text);
        }

        private void cmdClear_Click(object sender, EventArgs e)
        {
            txtDebugOutput.Text = string.Empty;
        }
        #endregion

        #region json functions

        private void deserialiseJSON(string strJSON)
        {
            try
            {               

                var jPerson = JsonConvert.DeserializeObject<JsonPersonComplex>(strJSON);
                

                debugOutput("Phone ID: " + jPerson.Id.ToString());
                debugOutput("Phone Number: " + jPerson.Phone_number.ToString());
                debugOutput("Valid Number: " + jPerson.Is_valid);
                debugOutput("Line Type: " + jPerson.Line_type);
                debugOutput("Carrier: " + jPerson.Carrier);
                debugOutput("Prepaid: " + jPerson.Is_prepaid);
                debugOutput("Commercial: " + jPerson.Is_commercial);

                debugOutput("Name:  " + jPerson.Belongs_to.FirstOrDefault().Name); 
                debugOutput("First Name: " + jPerson.Belongs_to.FirstOrDefault().Firstname);
                debugOutput("Middle Name: " + jPerson.Belongs_to.FirstOrDefault().Middlename);
                debugOutput("Last Name: " + jPerson.Belongs_to.FirstOrDefault().Lastname);
                debugOutput("Age Range: " + jPerson.Belongs_to.FirstOrDefault().Age_range);
                debugOutput("Gender: " + jPerson.Belongs_to.FirstOrDefault().Gender);
                debugOutput("Type: " + jPerson.Belongs_to.FirstOrDefault().Type);

                
                debugOutput("Street Address: " + jPerson.Current_address.FirstOrDefault().Street_line_1);              
                debugOutput("Extended Address: " + jPerson.Current_address.FirstOrDefault().Street_line_2);
                debugOutput("City: " + jPerson.Current_address.FirstOrDefault().City);
                debugOutput("Zip Code: " + jPerson.Current_address.FirstOrDefault().Postal_code);
                debugOutput("State: " + jPerson.Current_address.FirstOrDefault().State_code);
                debugOutput("Country: " + jPerson.Current_address.FirstOrDefault().Country_code);


                

            }
            catch (Exception ex)
            {
                debugOutput("We Had A Problem: " + ex.Message.ToString());
            }
        }



        #endregion

        #region Debug Output
        private void debugOutput(string strDebugText)
        {
            try
            {
                System.Diagnostics.Debug.Write(strDebugText + Environment.NewLine);
                txtDebugOutput.Text = txtDebugOutput.Text + strDebugText + Environment.NewLine;
                txtDebugOutput.SelectionStart = txtDebugOutput.TextLength;
                txtDebugOutput.ScrollToCaret();
            }
            catch (Exception ex)
            {
                System.Diagnostics.Debug.Write(ex.Message.ToString() + Environment.NewLine);
                
            }
        }

        #endregion
    }
}



Десериализовать Класс

namespace WhitePagesTool
{
    class JsonPersonComplex
    {
        public string Id { get; set; }
        public string Phone_number { get; set; }
        public bool Is_valid { get; set; }
        public string Line_type { get; set; }
        public string Carrier { get; set; }
        public bool Is_prepaid { get; set; }
        public bool Is_commercial { get; set; }
        public List<BelongsTo> Belongs_to { get; set; }
        public List<CurrentAddress> Current_address { get; set; }
        public List<LatLong> Lat_long { get; set; }
        public List<AssociatedPeople> Associated_people { get; set; }
    }

    public class BelongsTo
    {
        public string Name { get; set; }
        public string Firstname { get; set; }
        public string Middlename { get; set; }
        public string Lastname { get; set; }
        public string Age_range { get; set; }
        public string Gender { get; set; }
        public string Type { get; set; }
        

    }

    public class CurrentAddress
    {
        public string Street_line_1 { get; set; }
        public object Street_line_2 { get; set; }
        public string City { get; set; }
        public string Postal_code { get; set; }
        public string State_code { get; set; }
        public string Country_code { get; set; }
        public LatLong Lat_long { get; set; }
    }

    public class LatLong
    {
        public double Latitude { get; set; }
        public double Longitude { get; set; }
        public string Accuracy { get; set; }
    }

    public class AssociatedPeople
    {
        public string Name { get; set; }
        public string Firstname { get; set; }
        public string Middlename { get; set; }
        public string Lastname { get; set; }
        public string Relation { get; set; }
    }
}



И наконец строка JSON с которой я работаю

{
  "id": "Phone.ID.Number",
  "phone_number": "5555555555",
  "is_valid": true,
  "country_calling_code": "1",
  "line_type": "Landline",
  "carrier": "Suddenlink Communications",
  "is_prepaid": false,
  "is_commercial": false,
  "belongs_to": [
    {
      "id": "Person.ID.Number",
      "name": "John Json Doe",
      "firstname": "John",
      "middlename": "Json",
      "lastname": "Doe",
      "age_range": "30+",
      "gender": "Male",
      "type": "Person",
      "link_to_phone_start_date": "2018-01-01"
    }
  ],
  "current_addresses": [
    {
      "id": "Location.ID.Number",
      "location_type": "Address",
      "street_line_1": "123 Annoying Street",
      "street_line_2": null,
      "city": "CSharp",
      "postal_code": "12345",
      "zip4": "1234",
      "state_code": "FL",
      "country_code": "US",
      "lat_long": {
        "latitude": 12.345678,
        "longitude": -12.345678,
        "accuracy": "RoofTop"
      },
      "is_active": true,
      "delivery_point": "SingleUnit",
      "link_to_person_start_date": "2018-01-01"
    }
  ],
  "historical_addresses": [

  ],
  "associated_people": [
    {
      "id": "Person.ID.Number",
      "name": "Jane Doe",
      "firstname": "Jane",
      "middlename": null,
      "lastname": "Doe",
      "relation": "Household"
    },
    {
      "id": "Person.ID.Number",
      "name": "John J Doe",
      "firstname": "John",
      "middlename": "J",
      "lastname": "Doe",
      "relation": "Household"
    },
    {
      "id": "Person.ID.Number",
      "name": "John Json Doe",
      "firstname": "John",
      "middlename": "Json",
      "lastname": "Doe",
      "relation": "PotentialOwner"
    },
    {
      "id": "Person.ID.Number",
      "name": "Jane J Doe",
      "firstname": "Jane",
      "middlename": "J",
      "lastname": "Doe",
      "relation": "PotentialOwner"
    },
    {
      "id": "Person.ID.Number",
      "name": "Jane Json Doe",
      "firstname": "Jane",
      "middlename": "Json",
      "lastname": "Doe",
      "relation": "PotentialOwner"
    }
  ],
  "alternate_phones": [

  ],
  "error": null,
  "warnings": [

  ]
}


Richard Deeming

Если вы хотите обновить свой вопрос, Нажмите зеленую ссылку "улучшить вопрос" и отредактируйте свой вопрос.

НЕ опубликуйте свое обновление как "решение".

Рейтинг:
0

Graeme_Grant

Проблема в том, что вы неправильно сопоставляете свойства JSON со свойствами класса C#. Вот почему вы получаете ошибку.

Пожалуйста, посмотрите на Проблемы десериализации json в C# - Решение 1[^] чтобы правильно их сопоставить.