투케이2K

72. (kotlin/코틀린) JSONTokener 사용해 json 형식 데이터 파싱 수행 실시 본문

Kotlin

72. (kotlin/코틀린) JSONTokener 사용해 json 형식 데이터 파싱 수행 실시

투케이2K 2022. 9. 26. 15:56

[개발 환경 설정]

개발 툴 : AndroidStudio

개발 언어 : Kotlin

 

[소스 코드]

    // TODO [테스트 메소드 정의 실시]
    fun testMain(){
        Log.i("---","---")
        Log.d("//===========//","================================================")
        Log.i("","\n"+"[Test_Kotlin > testMain() 메소드 : 테스트 함수 동작 실시]")
        Log.d("//===========//","================================================")
        Log.i("---","---")


        /**
         * ------------------------------------
         * TODO [요약 설명]
         * ------------------------------------
         * 1. JSONTokener : 안드로이드 내부에 설치된 json 파싱 도구입니다.
         * ------------------------------------
         * 2. jsonObject 파싱 : JSONTokener(string).nextValue() as JSONObject
         * ------------------------------------
         * 3. jsonArray 파싱 : JSONTokener(string).nextValue() as JSONArray
         * ------------------------------------
         * 4. 참고 사이트 : https://developer.android.com/reference/kotlin/org/json/JSONTokener
         * ------------------------------------
         * */


        // [로직 처리 실시]
        try{
            // ------------------------------------
            // [초기 변수 선언 실시]
            var jsonString = "{\n" +
                    "   \"name\" : \"투케이\",\n" +
                    "   \"age\" : 29\n" +
                    "}"


            // [JSONTokener 사용해 jsonObject 파싱 실시]
            val jsonObject = JSONTokener(jsonString).nextValue() as JSONObject

            var parseName = jsonObject.getString("name")
            var parseAge = jsonObject.getString("age")


            // [로그 결과 출력 실시]
            Log.i("---","---")
            Log.w("//===========//","================================================")
            Log.i("","\n"+"[Test_Kotlin > testMain() 메소드 : 로그 출력 결과 확인]")
            Log.i("","\n"+"[parseName : "+ parseName +"]")
            Log.i("","\n"+"[parseAge : "+ parseAge +"]")
            Log.w("//===========//","================================================")
            Log.i("---","---")

            // ------------------------------------
        }
        catch(e : Exception){
            Log.i("---","---")
            Log.e("//===========//","================================================")
            Log.i("","\n"+"[Test_Kotlin > testMain() 메소드 : 에러 상황 발생]")
            Log.i("","\n"+"[error : "+e.message+"]")
            Log.e("//===========//","================================================")
            Log.i("---","---")
        }
    }
 

[결과 출력]

 

 

반응형
Comments