java Android解析JSON数据显示重复结果
我正在尝试从以下https://d17h27t6h515a5.cloudfront.net/topher/2017/May/59121517_baking/baking.json下载数据
这是我下载数据的Android代码
公共类DownloadTask扩展了AsyncTask{
private List<Ingredients> tIngredients = new ArrayList<>();
private List<Steps> tSteps = new ArrayList<>();
String result;
@Override
protected String doInBackground(String... params) {
result = "";
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder().url("https://d17h27t6h515a5.cloudfront.net/topher/2017/May/59121517_baking/baking.json").build();
try {
result = client.newCall(request).execute().body().string();
Log.i("RESULT", result);
JSONArray rootArray = new JSONArray(result);
for (int i = 0; i < rootArray.length(); i++) {
JSONObject tempObject = rootArray.getJSONObject(i);
JSONArray ingredients = tempObject.getJSONArray("ingredients");
for(int j = 0 ; j< ingredients.length(); j++) {
JSONObject tempIngredient = ingredients.getJSONObject(j);
Ingredients newIngredient = new Ingredients(tempIngredient.getString("quantity"),
tempIngredient.getString("measure"),
tempIngredient.getString("ingredient"));
tIngredients.add(newIngredient);
j++;
}
JSONArray steps = tempObject.getJSONArray("steps");
for (int k = 0; k < steps.length(); k++) {
JSONObject tempStep = steps.getJSONObject(k);
Steps newStep = new Steps(tempStep.getString("id"), tempStep.getString("shortDescription"),
tempStep.getString("description"), tempStep.getString("videoURL"));
tSteps.add(newStep);
}
Recipe newRecipe = new Recipe(tempObject.getString("id"), tempObject.getString("name"), tempObject.getString("servings"), tIngredients, tSteps);
MainActivity.mRecipies.add(newRecipe);
}
} catch (Exception e) {
Log.i("TAG", e.getMessage());
}
return null;
}
@Override
protected void onPostExecute(String s) {
for (int i = 0; i < MainActivity.mRecipies.size(); i++) {
Log.i("Recipie Number", String.valueOf(i));
for (int j = 0; j < MainActivity.mRecipies.get(i).getIngredients().size(); j++) {
Log.i("Ingre - ", MainActivity.mRecipies.get(i).getIngredients().get(j).getIngredient());
}
MainActivity.myList.setAdapter(MainActivity.myAdapter);
super.onPostExecute(s);
}
}
}
当我尝试检查下载的数据时,它会显示重复的结果和 有时甚至是奇怪的结果
打印时的日志
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Recipie Number: 0
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: Mascapone Cheese(room temperature)
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: cream cheese(softened)
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: Bittersweet chocolate (60-70% cacao)
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: large eggs
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: all purpose flour
06-21 05:16:01.402 26656-26656/com.example.vamshi.baking I/Ingre -: salt
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: sifted cake flour
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: baking powder
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla extract, divided
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: whole milk
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: egg whites
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:16:01.403 26656-26656/com.example.vamshi.baking I/Ingre -: heavy cream
06-21 05:16:01.404 26656-26656/com.example.vamshi.baking I/Recipie Number: 1
06-21 05:16:01.404 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: Mascapone Cheese(room temperature)
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: cream cheese(softened)
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: Bittersweet chocolate (60-70% cacao)
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: large eggs
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: all purpose flour
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: salt
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: sifted cake flour
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: baking powder
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla extract, divided
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: whole milk
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: egg whites
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: heavy cream
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Recipie Number: 2
06-21 05:16:01.405 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: Mascapone Cheese(room temperature)
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: cream cheese(softened)
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: Bittersweet chocolate (60-70% cacao)
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: large eggs
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: all purpose flour
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: salt
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: sifted cake flour
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: baking powder
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla extract, divided
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: whole milk
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: egg whites
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:16:01.406 26656-26656/com.example.vamshi.baking I/Ingre -: heavy cream
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Recipie Number: 3
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: Mascapone Cheese(room temperature)
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: cream cheese(softened)
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: Bittersweet chocolate (60-70% cacao)
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: large eggs
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: all purpose flour
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: salt
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: sifted cake flour
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: baking powder
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla extract, divided
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: whole milk
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: egg whites
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:16:01.407 26656-26656/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:16:01.408 26656-26656/com.example.vamshi.baking I/Ingre -: heavy cream
然后我想可能是因为我没有清理两个ArrayList 这是我为这两个命令添加clear命令时的结果
Log.i("RESULT", result);
JSONArray rootArray = new JSONArray(result);
for (int i = 0; i < rootArray.length(); i++) {
tIngredients.clear();
tSteps.clear();
JSONObject tempObject = rootArray.getJSONObject(i);
JSONArray ingredients = tempObject.getJSONArray("ingredients");
结果如下
06-21 05:21:50.464 32625-32625/com.example.vamshi.baking I/Recipie Number: 0
06-21 05:21:50.464 32625-32625/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:21:50.464 32625-32625/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:21:50.464 32625-32625/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:21:50.464 32625-32625/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:21:50.464 32625-32625/com.example.vamshi.baking I/Ingre -: heavy cream
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Recipie Number: 1
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: heavy cream
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Recipie Number: 2
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: heavy cream
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Recipie Number: 3
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: Graham Cracker crumbs
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: granulated sugar
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: vanilla,divided
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: large whole eggs
06-21 05:21:50.465 32625-32625/com.example.vamshi.baking I/Ingre -: heavy cream
请说明原因,提前谢谢
# 1 楼答案
您不需要字段
您需要每个配方的单独成分和步骤
您可能还想看看Why does my ArrayList contain N copies of the last item added to the list?
建议:
# 2 楼答案
这两条线需要进入循环中:
另外,第二个循环有一个额外的
j++
来删除它# 3 楼答案
在第二个循环中的doinbackground方法中,将j变量增加两倍,在循环j++中增加一倍,然后在循环j++中增加一倍。除非你们想跳过这些成分,否则你们应该删除循环中的j++