0

0

Java/Android中解析JSONArray并按特定键值筛选数据教程

聖光之護

聖光之護

发布时间:2025-11-30 13:50:33

|

227人浏览过

|

来源于php中文网

原创

Java/Android中解析JSONArray并按特定键值筛选数据教程

本教程详细介绍了如何在java/android环境中解析json数组(jsonarray),并根据特定键值(如电子邮件地址)筛选和提取所需数据,特别是经纬度信息。文章涵盖了json结构分析、迭代处理、数据提取、字符串清洗以及错误处理等关键步骤,旨在帮助开发者高效处理动态json数据。

理解JSON数组结构

在现代应用程序开发中,JSON(JavaScript Object Notation)已成为数据交换的标准格式。JSONArray代表一个有序的JSON值集合,通常包含多个JSONObject,每个JSONObject又是由键值对组成的无序集合。

以下是本文将处理的JSON数据示例,它是一个包含多个地理位置(lati和longt)及相关信息(如email)的数组:

[
    {
        "num": "34304",
        "email": "<a class="__cf_email__" data-cfemail="2f4e4e4e4e6f424e4643014e4b4b5d4a5c5c" href="/cdn-cgi/l/email-protection">[email protected]</a>",
        "lati": "8888888",
        "longt": "88888888",
        "time": "2022-12-08 21:15:39"
    },
    {
        "num": "34303",
        "email": "<a class="__cf_email__" data-cfemail="2c4d4d4d4d6c414d4540024d48485e495f5f" href="/cdn-cgi/l/email-protection">[email protected]</a>",
        "lati": "8888",
        "longt": "88888",
        "time": "8888888"
    }
    // ... 更多类似对象
]

请注意,email字段的值是一个HTML字符串,其中包含一个标签,包裹着实际的电子邮件地址。在解析和筛选时,我们需要对这个HTML字符串进行处理以提取纯文本的电子邮件地址。

Memo AI
Memo AI

AI音视频转文字及字幕翻译工具

下载

解析JSONArray并提取数据

解析JSONArray的基本步骤包括:将JSON字符串转换为JSONArray对象,然后遍历该数组,对每个JSONObject提取所需的数据。

立即学习Java免费学习笔记(深入)”;

1. 将JSON字符串转换为JSONArray

首先,你需要将接收到的JSON字符串转换为org.json.JSONArray对象。

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.util.ArrayList;
import java.util.List;

// 在Android项目中,你可能需要导入 android.text.Html
// import android.text.Html;

public class JsonDataProcessor {

    public static void processJsonData(String jsonString, String targetEmail) {
        List<String> filteredLatLongs = new ArrayList<>();

        try {
            JSONArray jsonArray = new JSONArray(jsonString);

            // 遍历JSONArray
            for (int i = 0; i < jsonArray.length(); i++) {
                JSONObject jsonObject = jsonArray.getJSONObject(i);

                // 提取email字段,并进行HTML解码
                String rawEmail = jsonObject.optString("email", "");
                String cleanedEmail;

                // 在Android环境中,使用Html.fromHtml进行解码
                // cleanedEmail = Html.fromHtml(rawEmail).toString();

                // 对于纯Java环境或简化示例,我们可以假设已经处理或直接使用
                // 这里为了演示,我们手动从HTML字符串中提取可见的邮箱文本
                if (rawEmail.contains("[email")) {
                    int startIndex = rawEmail.indexOf(">");
                    int endIndex = rawEmail.indexOf("</a>");
                    if (startIndex != -1 && endIndex != -1 && startIndex < endIndex) {
                        cleanedEmail = rawEmail.substring(startIndex + 1, endIndex);
                    } else {
                        cleanedEmail = rawEmail; // 如果格式不符,则使用原始字符串
                    }
                } else {
                    cleanedEmail = rawEmail; // 如果不是HTML格式,直接使用
                }

                // 根据电子邮件地址进行筛选
                if (targetEmail.equals(cleanedEmail)) {
                    String lati = jsonObject.getString("lati");
                    String longt = jsonObject.getString("longt");
                    filteredLatLongs.add("Lati: " + lati + ", Longt: " + longt);
                }
            }

            // 输出筛选结果
            System.out.println("针对邮箱 " + targetEmail + " 的筛选结果:");
            if (filteredLatLongs.isEmpty()) {
                System.out.println("未找到匹配的条目。");
            } else {
                for (String latLong : filteredLatLongs) {
                    System.out.println(latLong);
                }
            }

        } catch (JSONException e) {
            System.err.println("解析JSON时发生错误: " + e.getMessage());
        } catch (NumberFormatException e) {
            System.err.println("将经纬度字符串转换为数字时发生错误: " + e.getMessage());
        }
    }

    public static void main(String[] args) {
        String sampleJson = "[{"num": "34304","email": "<a class=\"__cf_email__\" data-cfemail=\"2f4e4e4e4e6f424e4643014e4b4b5d4a5c5c\" href=\"/cdn-cgi/l/email-protection\">[email protected]</a>","lati": "8888888","longt": "88888888","time": "2022-12-08 21:15:39"},{"num": "34303","email": "<a class=\"__cf_email__\" data-cfemail=\"2c4d4d4d4d6c414d4540024d48485e495f5f\" href=\"/cdn-cgi/l/email-protection\">[email protected]</a>","lati": "8888","longt": "88888","time": "8888888"},{"num": "34302","email": "<a class=\"__cf_email__\" data-cfemail=\"3c5e5e5e5e7c515d5550125d58584e594f4f\" href=\"/cdn-cgi/l/email-protection\">[email protected]</a>","lati": "8888","longt": "88888","time": "8888888"},{"num": "34301","email": "<a class=\"__cf_email__\" data-cfemail=\"7716161616371a161e1b5916131305120404\" href=\"/cdn-cgi/l/email-protection\">[email protected]</a>","lati": "8888","longt": "88888","time": "8888888"},{"num": "34300","email": "<a class=\"__cf_email__\" data-cfemail=\"1f7c7c7c7c5f727e7673317e7b7b6d7a6c6c\" href=\"/cdn-cgi/l/email-protection\">[email protected]</a>","lati": "8888","longt": "88888","time": "8888888"}]";
        String targetEmailToFilter = "[email protected]"; // 要筛选的邮箱

        processJsonData(sampleJson, targetEmailToFilter);
    }
}

2. 代码解释

  1. JSONArray jsonArray = new JSONArray(jsonString);: 这一行将原始的JSON字符串解析成一个JSONArray对象。
  2. for (int i = 0; i : 遍历JSONArray中的每一个元素。
  3. JSONObject jsonObject = jsonArray.getJSONObject(i);: 在每次迭代中,获取当前索引位置的JSONObject。
  4. String rawEmail = jsonObject.optString("email", "");: 使用optString方法安全地获取email字段的值。optString在键不存在时会返回默认值(这里是空字符串),而不是抛出JSONException。
  5. HTML解码处理:
  6. if (targetEmail.equals(cleanedEmail)) { ... }: 这是一个条件判断,用于检查当前对象的cleanedEmail是否与我们想要筛选的目标邮箱匹配。
  7. String lati = jsonObject.getString("lati");String longt = jsonObject.getString("longt");: 如果邮箱匹配成功,则提取lati和longt字段的值。getString方法在键不存在时会抛出JSONException,因此通常建议在确定键一定存在时使用,或者配合optString进行更安全的访问。
  8. 错误处理: 使用try-catch块捕获JSONException(JSON解析错误)和NumberFormatException(如果尝试将非数字字符串转换为数字)。

注意事项与最佳实践

  • 异常处理: 始终使用try-catch块来处理JSONException,因为JSON解析过程中可能会出现格式错误。
  • 安全获取值:
    • 使用optString(key, defaultValue)、optInt(key, defaultValue)等opt系列方法,可以在键不存在时返回一个默认值,而不是抛出异常,这使得代码更健壮。
    • 如果你确定某个键一定存在且其值类型已知,可以使用getString(key)、getInt(key)等方法,它们会在键不存在或类型不匹配时抛出JSONException。
  • HTML内容处理: 如果JSON中的字符串包含HTML标签(如示例中的email字段),在Android中使用Html.fromHtml()是提取纯文本的常用且有效的方法。对于更复杂的HTML解析需求,可以考虑引入第三方库如Jsoup。
  • 数据类型转换: 经纬度通常是浮点数。在提取字符串后,如果需要进行数值计算,记得将其转换为double类型,例如Double.parseDouble(lati)。
  • 性能: 对于非常大的JSONArray,频繁的字符串操作和对象创建可能会影响性能。在处理海量数据时,考虑优化数据结构或使用流式解析。
  • 目标邮箱匹配: 示例中的[email protected]实际上是Cloudflare的邮件保护机制。Html.fromHtml()会将其解析为可见的文本。如果实际需要匹配的是原始的、未

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

336

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

224

2025.10.31

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

138

2026.02.12

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.9万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号