이 글에서는 주로 ASP.NET을 사용하여 다층 중첩 json 데이터를 추출하는 방법과 타사 클래스 라이브러리 Newtonsoft.Json을 사용하여 다층 중첩 json 데이터를 추출하는 방법을 소개합니다. 더 자세히 알아보세요.
이 문서의 예에서는 타사 클래스 라이브러리 Newtonsoft.Json을 사용하여 ASP.NET에서 다중 계층 중첩 json 데이터를 추출하는 방법을 설명합니다. 구체적인 예는 다음과 같습니다.
추출해야 하는 json 문자열이 다음과 같다고 가정합니다.
{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}
먼저 네임스페이스를 인용합니다.
using Newtonsoft.Json; using Newtonsoft.Json.Linq;
위의 json 문자열을 객체로 처리할 수 있으며 해당 클래스를 작성하면 됩니다. (개발용으로 VS2013을 사용하는 경우 "편집 - 선택하여 붙여넣기 - JSON을 class "json 문자열을 엔터티 클래스로 빠르게 변환)
public class UserInfo { public string name; public int age; public address addr; } public class address { public string city; public string province; }
1. json 문자열을 엔터티 객체로 변환하는 코드는 다음과 같습니다.
string jsonData="{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":guangzhou,\"province\":guangdong}}"; UserInfo user=(UserInfo)JsonConvert.DeserializeObject(jsonData, typeof(UserInfo));
2. json에서 속성 값을 읽으려면 다음 코드를 사용할 수 있습니다:
JObject jsonObj = JObject.Parse(jsonData); string name=jsonObj ["name"].ToString(); string age=jsonObj ["age"].ToString(); string city=((JObject )jsonObj ["addr"])["city"].ToString(); string province=((JObject )jsonObj ["addr"])["province"].ToString();
3 , 다중 계층 중첩 json을 해석하고 속성 값을 가져옵니다.
처리해야 하는 json 문자열이 다음과 같은 경우:
{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}};
그러면 let "city"와 같은 객체를 입력하면 시스템은 "guangzhou"를 출력하고, "age"를 입력하면 "23"을 출력합니다. json은 다단계 중첩이므로 하나씩 순회해야 합니다. 코드는 다음과 같습니다.
public string GetJsonValue(JEnumerable<JToken> jToken, string key) { IEnumerator enumerator = jToken.GetEnumerator(); while (enumerator.MoveNext()) { JToken jc = (JToken)enumerator.Current; if (jc is JObject || ((JProperty)jc).Value is JObject) { return GetJsonValue(jc.Children(), key); } else { if (((JProperty)jc).Name == key) { return ((JProperty)jc).Value.ToString(); } } } return null; }
GetJsonValue 호출 코드:
string jsonData = "{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":\"guangzhou\",\"province\":\"guangdong\"}}"; JObject jsonObj = JObject.Parse(jsonData); Response.Write(GetJsonValue(jsonObj.Children(), "province"));
다층 중첩 배열인 경우 다음 코드를 사용할 수도 있습니다.
string jsonData = "{\"addr\":[{\"city\":\"guangzhou\",\"province\":\"guangdong\"},{\"city\":\"guiyang\",\"province\":\"guizhou\"}]}"; JObject jsonObj = JObject.Parse(jsonData); JArray jar = JArray.Parse(jsonObj["addr"].ToString()); JObject j = JObject.Parse(jar[0].ToString()); Response.Write(j["city"]);
4. JSON을 XML로:
다음과 같이 코드를 복사합니다.
string xmlstr=((XmlDocument)JsonConvert.DeserializeXmlNode( jsonData)).InnerXml.ToString();
위 내용은 모두의 학습에 도움이 되기를 바랍니다. .
ASP.NET이 다중 계층 중첩 json 데이터를 추출하는 방법에 대한 자세한 설명과 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!