在C#中访问消息元素的内部嵌套JSON数组

时间:2017-10-28 22:58:10

标签: c# .net arrays json.net jsonparser

我试图访问内部JSON消息数组元素,如下面示例JSON字符串中所示。

{"chats":
[
//////////1ST CHAT
{"type":"chat",
"id":"OYTHUUBLB2",
"tickets":[],
"visitor_name":"Shen",
"visitor_id":"value",
"visitor_ip":"val",
"visitor":
             {"id":"",
    "name":"Shen",
    "email":"shen@gmail.com",
    "ip":"val",
    "city":"Brampton",
    "region":"Ontario",
    "country":"Canada",
    "country_code":"CA",
    "timezone":"America/Rainy_River"},
"agents":[
    {"display_name":"Kim",
    "email":"val@email.com",
    "ip":"72."},
    ],
"supervisors":[],
    "rate":"not_rated",
    "duration":213,
    "chat_start_url":"httpsjj",
    "group":[3],
    "started":"Fri 10/27/17 01:12:38 pm",
    "pending":false,
"tags":[],
"timezone":"America/Bogota",
"messages":[
        {
        "author_name":"Kim",
        "text":"Hello Shenelle. How may I help you?",
        "date":"Fri10/27/17 01:12:38 pm",
        "timestamp":1509127958,
        "agent_id":"val",
        "user_type":"agent",
        "type":"message",
        "welcome_message":true,
                     }
        {"author_name":"Shenelle",
        "text":"I would like",
        "date":"Fri 10/27/17 01:12:56 pm",
        "timestamp":1509127976,
        "user_type":"visitor",
        "type":"message"},
                 {
        "author_name":"Shenelle",
        "text":"helooooooooooooooooo",
        "date":"Fri10/27/17 01:15:47 pm",
        "timestamp":1509128147,
        "user_type":"visitor",
        "type":"message"},
                  ]

这是我在C#中已经尝试过的。我可以访问其他元素,但它只是内部嵌套的JSON消息数组是我的问题。任何人都可以帮助访问[text]元素的代码?我只想在单个特定ChatIndex上的[text]元素上连接所有迭代。我的最终结果是连接每个单独聊天的所有[text]元素。

 //  JObject chatMessage = JObject.Parse(result);
        dynamic chatMessage = JsonConvert.DeserializeObject(result);


     int totalChats = (int)chatMessage["total"];//totalChats gives count of all individual chats

        for(int chatIndex = 0; chatIndex < totalChats; chatIndex++)
        {
            string id = (string)chatMessage["chats"][chatIndex]["id"];
      string city = (string)chatMessage["chats"][chatIndex]["visitor"]["city"];
            string region = (string)chatMessage["chats"][chatIndex]["visitor"]["region"];
            string country = (string)chatMessage["chats"][chatIndex]["visitor"]["country"];
            string visitorName = (string)chatMessage["chats"][chatIndex]["visitor"]["name"];
            string visitorEmail = (string)chatMessage["chats"][chatIndex]["visitor"]["email"];

            Console.WriteLine("ID: "+id+ "\nVisitor Name: " +visitorName+ "\nVisitor Email:"+visitorEmail
               + "\nVisitor City:"+ city + "\nVisitor Region:"+region +"\nCountry of visitor:"+ country);

            //   int messageIndex = chatMessage["chats"][chatIndex]["messages"].length;
            // foreach (var messageIndex in chatMessage.messages)
            //  {
            for (int messageIndex = 0; messageIndex < chatMessage["chats"][chatIndex]["messages"]; messageIndex++) { 

                //   string msg = (string)chatMessage["chats"][chatIndex]["messages"][messageIndex]["author_name"];
           string text = (string)chatMessage["chats"][chatIndex]["messages"][messageIndex]["text"];
               // string.Concat(","+text);
                Console.WriteLine("\n TEXT:"+text);
                            }

            Console.WriteLine(""); //x++;
        }

2 个答案:

答案 0 :(得分:2)

使用 Newtonsoft.Json 并在 JsonConvert.DeserializeObject 之后,您可以在此处浏览嵌套项:

int messageNumber = chatMessage.messages.Count;
for (int i = 0; i < messageNumber; i++)
{
    Console.WriteLine(chatMessage.messages[i].text);
}

答案 1 :(得分:2)

 int messageNumber = chatMessage["chats"][chatIndex]["messages"].Count;
            for (int i = 0; i < messageNumber; i++)
            {
                string text = (string)chatMessage["chats"][chatIndex]["messages"][i]["text"];
                Console.WriteLine(text);
            }

这解决了这个问题。不得不将那些上层嵌套元素放到位。原来代码上我需要的就是将.Count添加到chatMessage [&#34;聊天&#34;] [chatIndex] [&#34;消息&#34;]