Reputation: 757
How can I get the length of a JSON Array I get using json.net in C#? After sending a SOAP call I get a JSON string as answer, I use json.net to parse it.
Example of the json I got:
{"JSONObject": [
{"Id":"ThisIsMyId","Value":"ThisIsMyValue"},
{"Id":"ThisIsMyId2","Value":"ThisIsMyValue2"}
]}
And I parse it and write it in console:
var test = JObject.Parse (json);
Console.WriteLine ("Id: {0} Value: {1}", (string)test["JSONObject"][0]["Id"], (string)test["JSONObject"][0]["Value"]);
This works like a spell, only I don't know the length of the JSONObject
, but I need to do it in a for loop. I only have no idea how I can get the length of test["JSONObject"]
But something like test["JSONObject"].Length
would be too easy I guess :(..
Upvotes: 46
Views: 99307
Reputation: 17748
The easiest and cleanest way I found:
int length = test["JSONObject"].Count;
Upvotes: 4
Reputation: 23
This worked for me supposing the json data is in a json file. In this case, .Length works but no intellisence is available:
public ActionResult Index()
{
string jsonFilePath = "C:\\folder\\jsonLength.json";
var configFile = System.IO.File.ReadAllText(jsonFilePath);
JavaScriptSerializer jss = new JavaScriptSerializer();
var d = jss.Deserialize<dynamic>(configFile);
var jsonObject = d["JSONObject"];
int jsonObjectLength = jsonObject.Length;
return View(jsonObjectLength);
}
Upvotes: 2
Reputation: 561
Just try this:
var test= ((Newtonsoft.Json.Linq.JArray)json).Count;
Upvotes: 3
Reputation: 1751
You can use below line to get the length of JSON Array in .Net (JArray
) .
int length = ((JArray)test["jsonObject"]).Count;
Upvotes: 3
Reputation: 48425
You can cast the object to a JArray
and then use the Count
property, like so:
JArray items = (JArray)test["JSONObject"];
int length = items.Count;
You can then loop the items as follows:
for (int i = 0; i < items.Count; i++)
{
var item = (JObject)items[i];
//do something with item
}
According to Onno (OP), you can also use the following:
int length = test["JSONObject"].Count();
However, I have not personally confirmed that this will work
Upvotes: 86