Sto passando un array JSON dall'attività A all'attività B. Quindi sto utilizzando la libreria GSON per inserire un valore nell'array. Questo è il mio codice corrente.Convertire un array JSON in un oggetto json in Android usando gson?
public void gsonResponse(String json) {
try {
JSONObject jsonObject = new JSONObject(json);
JSONArray jsonArray = jsonObject.getJSONArray("result");
for (int i = 0; i < jsonArray.length(); i++) {
LinkedHashMap<String, String> linkedHashMap = new LinkedHashMap<>();
JSONObject innerJosonObject = new JSONObject(jsonArray.getString(i));
// you need to put all values from jsonObject to map for managing the order..
linkedHashMap.put("doc_no", textViewInvNo.getText().toString());
linkedHashMap.put("itembarcode", innerJosonObject.getString("itembarcode"));
linkedHashMap.put("net_wt", innerJosonObject.getString("net_wt"));
linkedHashMap.put("gross_wt", innerJosonObject.getString("gross_wt"));
linkedHashMap.put("stone_wt", innerJosonObject.getString("stone_wt"));
linkedHashMap.put("stone_amt", innerJosonObject.getString("stone_amt"));
linkedHashMap.put("rate", innerJosonObject.getString("rate"));
linkedHashMap.put("making", innerJosonObject.getString("making"));
linkedHashMap.put("qty", innerJosonObject.getString("qty"));
linkedHashMap.put("net_rate", innerJosonObject.getString("net_rate"));
linkedHashMap.put("item_total", innerJosonObject.getString("item_total"));
linkedHashMap.put("sum_total", innerJosonObject.getString("sum_total"));
Gson gson = new Gson();
// convert linkedHashMap to json string and it will keep the insertion order..
String string = gson.toJson(linkedHashMap, LinkedHashMap.class);
jsonArray.put(i, string);
}
jsonObject.put("result", jsonArray);
String jsonResp = jsonObject.toString();
jsonFormattedString = jsonResp.replaceAll("\\\\","");
Log.d("NEW JSON", jsonFormattedString);
} catch (JSONException e) {
e.printStackTrace();
}
}
L'uscita per questo è: -
{"result":["{"doc_no":"ES101","itembarcode":"BRMS","net_wt":"10","gross_wt":"1","stone_wt":"0","stone_amt":"0","rate":"32000","making":"100","qty":"1","net_rate":"32100.0","item_total":"32100.0","sum_total":"64600.0"}",
"{"doc_no":"ES101","itembarcode":"MSAA0015","net_wt":"10","gross_wt":"11","stone_wt":"100000","stone_amt":"1","rate":"32000","making":"500","qty":"1","net_rate":"32500.0","item_total":"32500.0","sum_total":"64600.0"}"]}
Ma il mio output desiderato dovrebbe essere qualcosa di simile: -
[{"doc_no":"IN1001","itembarcode":"BRMS123456\nFLT22K","net_wt":"10","gross_wt":"10","stone_amt":"0","rate":"29000","making":"999","qty":"1","net_rate":"29999.0","item_total":"29999.0","sum_total":"30299.0","stone_wt":"0"},
{"doc_no":"IN1001","itembarcode":"BRMS\nGA24K","net_wt":"10","gross_wt":"1","stone_amt":"0","rate":"32000","making":"100","qty":"1","net_rate":"","item_total":"","sum_total":"30299.0","stone_wt":""}]
Come posso raggiungerlo? Qualsiasi suggerimento o aiuto è apprezzato. Grazie.
Hey questo è facile e sembra funzionare l'unico problema è che ottengo quotes.How in più posso sbarazzati di loro. [ "{" Doc_no ":" IN1002" , "itembarcode": "BRMS", "net_wt": "10", "gross_wt": "1", "stone_wt": "0", "stone_amt": "0" , "rate": "32000", "lavorazione": "100", "qty": "1", "net_rate": "32100,0", "ITEM_TOTAL": "32100,0", "sum_total": "64600,0"}" , "{" doc_no ":" IN1002 "," itembarcode ":" MSAA0015 "," net_wt ":" 10 "," gross_wt ":" 11 "," stone_wt ":" 100000 "," stone_amt ":" 1 ", "rate": "32000", "fare": "500", "qty": "1", "net_rate": "32500,0", "ITEM_TOTAL": "32500,0", "sum_total": "64600,0"} "] –
ma la dimensione dell'array continua a cambiare. Non sarà sempre 2. –
fornisce questo output ["" doc_no ":" IN1002 "," itembarcode ":" BRMS "," net_wt ":" 10 "," gross_wt ":" 1 "," stone_wt ":" 0 "," stone_amt " : "0", "rate": "32000", "lavorazione": "100", "qty": "1", "net_rate": "32100,0", "ITEM_TOTAL": "32100,0", "sum_total":" 64600,0 "", "" doc_no ":" IN1002" , "itembarcode": "MSAA0015", "net_wt": "10", "gross_wt": "11", "stone_wt": "100000", "stone_amt":" 1" , "rate": "32000", "fare": "500", "qty": "1", "net_rate": "32500,0", "ITEM_TOTAL": "32500,0", "sum_total": "64600,0" "] –