перетворення з рядка в json об'єкт Android


107

Я працюю над додатком для Android. У своєму додатку я повинен перетворити рядок у об’єкт Json, а потім проаналізувати значення. Я перевірив рішення в stackoverflow і знайшов подібне питання тут за посиланням

Рішення таке

       `{"phonetype":"N95","cat":"WP"}`
        JSONObject jsonObj = new JSONObject("{\"phonetype\":\"N95\",\"cat\":\"WP\"}");

Я використовую той самий спосіб у своєму коді. Моя рядок є

{"ApiInfo":{"description":"userDetails","status":"success"},"userDetails":{"Name":"somename","userName":"value"},"pendingPushDetails":[]}

string mystring= mystring.replace("\"", "\\\"");

І після заміни я отримав такий результат

{\"ApiInfo\":{\"description\":\"userDetails\",\"status\":\"success\"},\"userDetails\":{\"Name\":\"Sarath Babu\",\"userName\":\"sarath.babu.sarath babu\",\"Token\":\"ZIhvXsZlKCNL6Xj9OPIOOz3FlGta9g\",\"userId\":\"118\"},\"pendingPushDetails\":[]}

коли я страчу JSONObject jsonObj = new JSONObject(mybizData);

Я отримую нижче виняток json

org.json.JSONException: Expected literal value at character 1 of

Будь ласка, допоможіть мені вирішити своє питання.


Я думаю, що ображаючий персонаж є зворотною косою рисою через вашу заміну. Чому саме ти це робиш? Звідки береться рядок JSON?
tiguchi

Я отримую рядок з html..не як json
sarath

1
Просто видаліть mystring = mystring.replace ("\" "," \\\ ""); і подивіться, чи працює він для вас тоді.
tiguchi

Відповіді:


227

Видаліть косоокість:

String json = {"phonetype":"N95","cat":"WP"};

try {

    JSONObject obj = new JSONObject(json);

    Log.d("My App", obj.toString());

} catch (Throwable t) {
    Log.e("My App", "Could not parse malformed JSON: \"" + json + "\"");
}

4
що робити, якщо рядок є масивом об'єктів JSON? На кшталт "[{}, {}, {}]"
Франсіско Корралес Моралес

3
@FranciscoCorralesMorales ви можете використовувати JSONArray obj = new JSONArray(json);. Потім ви можете використовувати for-цикл для ітерації через масив.
Філ

2
@FranciscoCorralesMorales просто використовує блок " спробу лову ". Якщо одне не вдається, припустимо інше.
Філ

1
@ ripDaddy69 Це здається, що JSON недійсний. Він очікує спарювання ключових значень, оточених фігурними дужками. Спробуйте щось на кшталт {"Fat cat":"meow"}.
Філ

2
@Phil Це, здається, не є дійсним завданням Java-String. Я не розумію, що я роблю по-іншому, хоча JSONObject obj = new JSONObject ("Жирна кішка": "мяу"); Я зрозумів це, мені потрібно було використовувати \ infront цитати, а потім фактичні цитати навколо всієї справи. Дякую.

31

її робота

    String json = "{\"phonetype\":\"N95\",\"cat\":\"WP\"}";

    try {

        JSONObject obj = new JSONObject(json);

        Log.d("My App", obj.toString());
        Log.d("phonetype value ", obj.getString("phonetype"));

    } catch (Throwable tx) {
        Log.e("My App", "Could not parse malformed JSON: \"" + json + "\"");
    }

1
Хоча це відповідає на питання, воно не пояснює, чому і як це працює. Будь ласка, додайте таке пояснення.
CerebralFart

Здається, що просте рішення коду вимагає створення іншого об'єкта, який обробляє послідовність втечі.
келалака

7

спробуйте це:

String json = "{'phonetype':'N95','cat':'WP'}";

2
що робити, якщо рядок є масивом об'єктів JSON? На кшталт "[{}, {}, {}]"
Франциско Корралес Моралес

Це гарна ідея. Одиночна цитата працює, і вона виключає необхідність втечі символів.
david m lee

1
Апостроф може працювати в JAVA, але це не суворо юридичний JSON. Тому вам може знадобитися робити інакше в інших мовах чи ситуаціях.
Джессі Чісгольм

4

Щоб отримати JSONObject або JSONArray з String, я створив цей клас:

public static class JSON {

     public Object obj = null;
     public boolean isJsonArray = false;

     JSON(Object obj, boolean isJsonArray){
         this.obj = obj;
         this.isJsonArray = isJsonArray;
     }
}

Тут можна отримати JSON:

public static JSON fromStringToJSON(String jsonString){

    boolean isJsonArray = false;
    Object obj = null;

    try {
        JSONArray jsonArray = new JSONArray(jsonString);
        Log.d("JSON", jsonArray.toString());
        obj = jsonArray;
        isJsonArray = true;
    }
    catch (Throwable t) {
        Log.e("JSON", "Malformed JSON: \"" + jsonString + "\"");
    }

    if (object == null) {
        try {
            JSONObject jsonObject = new JSONObject(jsonString);
            Log.d("JSON", jsonObject.toString());
            obj = jsonObject;
            isJsonArray = false;
        } catch (Throwable t) {
            Log.e("JSON", "Malformed JSON: \"" + jsonString + "\"");
        }
    }

    return new JSON(obj, isJsonArray);
}

Приклад:

JSON json = fromStringToJSON("{\"message\":\"ciao\"}");
if (json.obj != null) {

    // If the String is a JSON array
    if (json.isJsonArray) {
        JSONArray jsonArray = (JSONArray) json.obj;
    }
    // If it's a JSON object
    else {
        JSONObject jsonObject = (JSONObject) json.obj;
    }
}

Ви можете просто протестувати перший символ рядка JSON, щоб побачити, чи є він, [чи {знати, чи це масив чи об’єкт. Тоді ви б не ризикували обома винятками, лише відповідним.
Джессі Чисгольм

3

просто спробуйте це, нарешті, це працює для мене:

//delete backslashes ( \ ) :
            data = data.replaceAll("[\\\\]{1}[\"]{1}","\"");
//delete first and last double quotation ( " ) :
            data = data.substring(data.indexOf("{"),data.lastIndexOf("}")+1);
            JSONObject json = new JSONObject(data);

3

Вам просто потрібні рядки коду, як показано нижче:

 try {
        String myjsonString = "{\"phonetype\":\"N95\",\"cat\":\"WP\"}";
        JSONObject jsonObject = new JSONObject(myjsonString );
        //getting specific key values
        Log.d("phonetype = ", jsonObject.getString("phonetype"));
        Log.d("cat = ", jsonObject.getString("cat");
    }catch (Exception ex) {
         StringWriter stringWriter = new StringWriter();
         ex.printStackTrace(new PrintWriter(stringWriter));
         Log.e("exception ::: ", stringwriter.toString());
    }

0

Ось код, і ви можете вирішити, який
(синхронізований) StringBuffer або швидший StringBuilder використовувати.

Бенчмарк показує, що StringBuilder швидше.

public class Main {
            int times = 777;
            long t;

            {
                StringBuffer sb = new StringBuffer();
                t = System.currentTimeMillis();
                for (int i = times; i --> 0 ;) {
                    sb.append("");
                    getJSONFromStringBuffer(String stringJSON);
                }
                System.out.println(System.currentTimeMillis() - t);
            }

            {
                StringBuilder sb = new StringBuilder();
                t = System.currentTimeMillis();
                for (int i = times; i --> 0 ;) {
                     getJSONFromStringBUilder(String stringJSON);
                    sb.append("");
                }
                System.out.println(System.currentTimeMillis() - t);
            }
            private String getJSONFromStringBUilder(String stringJSONArray) throws JSONException {
                return new StringBuffer(
                       new JSONArray(stringJSONArray).getJSONObject(0).getString("phonetype"))
                           .append(" ")
                           .append(
                       new JSONArray(employeeID).getJSONObject(0).getString("cat"))
                      .toString();
            }
            private String getJSONFromStringBuffer(String stringJSONArray) throws JSONException {
                return new StringBuffer(
                       new JSONArray(stringJSONArray).getJSONObject(0).getString("phonetype"))
                           .append(" ")
                           .append(
                       new JSONArray(employeeID).getJSONObject(0).getString("cat"))
                      .toString();
            }
        }

0

Може бути внизу, краще.

JSONObject jsonObject=null;
    try {
        jsonObject=new JSONObject();
        jsonObject.put("phonetype","N95");
        jsonObject.put("cat","wp");
        String jsonStr=jsonObject.toString();
    } catch (JSONException e) {
        e.printStackTrace();
    }
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.