/ / Obtenir une erreur lors de l’analyse des données JSON sous android - android, json

Obtenir des erreurs lors de l'analyse des données JSON dans android - android, json

je reçois cette erreur

Error in parsing Dataorg.json.JSONException: Value ["AACHI"] at 0 of type org.json.JSONArray cannot be converted to JSONObject

Process: info.androidhive.materialdesign, PID: 18373
java.lang.NullPointerException: Attempt to invoke virtual method "java.lang.Object android.content.Context.getSystemService(java.lang.String)" on a null object reference

ce sont mes données JSON que je suis en train d'analyser.`[[" "AACHI"], ["AJAY COMPANY"], ["ALL OUT"], ["AMBICA"], ["AMICO PRODUCTS"], ["AMUL"], ["ANAND BHOG PRODUCTS"], [ "ANNAPURNA"], ["ANOOS PRODUCTS"], ["ARVIND LABORATORIES"], ["ASWINI PHARMACEUTICALS"], ["ATTK PRODUCTS"], ["AVA"], ["BAJAJ PRODUCTS"], ["BAMBINO" ], ["BANJARAS PRODUCTS"], ["BHAGAYALAKSHIMI PRODUCTS"], ["BRITANNIA"], ["cadbury"]]

Ceci est mon extrait de code pour analyser les données JSON.

 class DownloadJson extends AsyncTask {

Activity context;
ListView myListView;

private  ProgressDialog dialog = new ProgressDialog(getActivity());
public DownloadJson(Activity context, ListView myListView) {
this.myListView = myListView;
this.context = context;

}

public DownloadJson() {

}


@Override
protected void onPreExecute() {

this.dialog.setMessage("Please wait");
this.dialog.show();
}

@Override
protected void onCancelled() {
super.onCancelled();
}

@Override
protected Object doInBackground(Object[] params) {
String result = null;
InputStream isr = null;
String imageId = null;
String ip = "http://ganarajsshetti.tk/mobileapp/selectjson.php/";
try {

HttpClient httpClient = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(ip);
HttpResponse httpResponse = httpClient.execute(httpGet);
HttpEntity httpEntity = httpResponse.getEntity();
isr = httpEntity.getContent();
} catch (Exception e) {
Log.e("log_tag", "Error in http Connection" + e.toString());

}
// converting response to string
try {
BufferedReader br = new BufferedReader(new InputStreamReader(isr));
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = br.readLine()) != null) {
sb.append(line + "n");
}
isr.close();
result = sb.toString();

} catch (Exception e) {
Log.e("log_tag", "Error in Converting Data" + e.toString());
}

// parse JSON data

try {

JSONArray jsonArray = new JSONArray(result);
strListView = new String[jsonArray.length()];
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject json_data = jsonArray.getJSONObject(i);

strListView[i] = json_data.getString("Num_Rows");

System.out.println("--------------"+json_data.getString("Num_Rows"));

Log.e("ACK_tag", "DATA" + strListView[i]);
}

} catch (Exception e) {
Log.e("log_tag", "Error in parsing Data" + e.toString());
}

return null;

}

@Override
protected void onPostExecute(Object o) {
//objAdapter = new ArrayAdapter<String>(context,R.layout.vendorwithimage,R.id.venderdescrip,strListView);
if (dialog.isShowing()) {
dialog.dismiss();
}
callCustomAdaper(context);


}
}
@Override
public void onStop() {
super.onStop();
if (task.getStatus() == AsyncTask.Status.RUNNING)
task.cancel(true);
if (task.getStatus() == AsyncTask.Status.RUNNING)
task.cancel(true);

}

`

Réponses:

0 pour la réponse № 1

Essayez en changeant les lignes

JSONObject json_data = jsonArray.getJSONObject(i);
strListView[i] = json_data.getString("Num_Rows");

à

JSONArray innerJsonArray = jsonArray.getJSONArray(i);
strListView[0] = json_data.get(0);

2 pour la réponse № 2

Son tableau de matrices JSON. C'est comme un tableau 2D.

JsonArray jsonarray= new JsonArray(json);
for (int i = 0; i < jsonArray.length(); i++) {
strListView[i] = jsonarray.getJsonArray(i);


}

Source du lien:https://www.json.com/json-array


1 pour la réponse № 3

JSONObject json_data = jsonArray.getJSONObject (i);

Ici, "jsonArray" contient un objet tableau, pas un objet json. Donc, vous devez changer cela en JsonArray

  JSONArray jsonArrayElement = jsonArray.getJSONArray(0);

Et aussi ce JSON est valide mais pas conventionnel ou utile .. !!

Consultez plus d'informations pour json ici.


0 pour la réponse № 4

Essaye ça. fonctionne bien

String json = "[["AACHI"],["AJAY COMPANY"],["ALL OUT"],["AMBICA"],["AMICO PRODUCTS"],["AMUL"],["ANAND BHOG PRODUCTS"],["ANNAPURNA"],["ANOOS PRODUCTS"],["ARVIND LABORATORIES "],["ASWINI PHARMACEUTICALS"],["ATTK PRODUCTS"],["AVA"],["BAJAJ PRODUCTS "],["BAMBINO"],["BANJARAS PRODUCTS"],["BHAGAYALAKSHIMI PRODUCTS"],["BRITANNIA"],["cadbury"]]";
try {
JSONArray jsAr = new JSONArray(json);
String job="";
for(int i=0;i<jsAr.length();i++)
{
JSONArray js1 = jsAr.getJSONArray(i);
job += js1.getString(0);

}
Toast.makeText(this,job,Toast.LENGTH_LONG).show();

} catch (JSONException e) {
// TODO Auto-generated catch block

Toast.makeText(this,"Error",Toast.LENGTH_LONG).show();
e.printStackTrace();
}