java 将jsonarray 转化为对应键值的jsonobject

简介: 有时候我们再操作数据的时候,很多数据是jsonarry 格式的 如:[{"name":"测试数据","id":1},{"name":"测试数据2","id":2}]这样的格式很类型表格数据类型。但是我们要取id 为1的name 这样我们就要先变量以便了。如果需要多次操作这样的类型,显得很麻烦。这里的数据我们可以看出id 是唯一的。那么我们可以想办法将其转为jso

有时候我们再操作数据的时候,很多数据是jsonarry 格式的
如:

[{"name":"测试数据","id":1},{"name":"测试数据2","id":2}]

这样的格式很类型表格数据类型。但是我们要取id 为1的name 这样我们就要先变量以便了。如果需要多次操作这样的类型,显得很麻烦。

这里的数据我们可以看出id 是唯一的。那么我们可以想办法将其转为jsonobject 这样我们就很方便 根据指定id 获取 name 了。

 public static JSONObject toJSONObject(JSONArray jsonArray, String key) {
        JSONObject jsonObject = new JSONObject();
        for (int i = 0; i < jsonArray.size(); i++) {
            JSONObject temp = jsonArray.getJSONObject(i);
            String[] keyValues = StringUtil.StringToArray(key);
            if (keyValues != null) {
                for (String item : keyValues) {
                    String[] k = item.split(":");
                    String[] keys = k[0].split("_");
                    String keyName = k[0];
                    if (keys.length == 2) {
                        keyName = keys[0];
                    }
                    String jsonKeyName = temp.getString(keyName);
                    if (keys.length == 2) {
                        jsonKeyName += "_" + keys[1];
                    }
                    jsonObject.put(jsonKeyName, temp.getString(k[1]));
                }
            }
        }
        return jsonObject;
    }

这个方法就可以简单的实现,但是可能不是最好的实现方法。欢迎对其提出宝贵的建议。

这里列出各个案例
案例1:

原数据:
[{"name":"测试数据","id":1},{"name":"测试数据2","id":2}]

调用方法:
toJSONObject(jsonArray, "id:name")

结果:
{"1":"测试数据","2":"测试数据2"}

案例2:(这仅是我们自己业务需要添加上的)

原数据:
[{"name":"测试数据","id":1},{"name":"测试数据2","id":2}]

调用方法:
toJSONObject(jsonArray, "id_test:name")

结果:
{"1_test":"测试数据","2_test":"测试数据2"}

案例三:

原数据:
[{"no":100,"name":"测试数据","id":1,"desc":"测试描述"},{"no":101,"name":"测试数据2","id":2,"desc":"测试描述2"}]

调用方法:
toJSONObject(jsonArray, "id:name,no:desc")

结果:
{"1":"测试数据","100":"测试描述","2":"测试数据2","101":"测试描述2"}
相关文章
|
1月前
|
Java 存储
键值之道:深入学习Java中强大的HashMap(二)
键值之道:深入学习Java中强大的HashMap
55 0
键值之道:深入学习Java中强大的HashMap(二)
|
6月前
|
JSON Java fastjson
Java String转JSONObject时保持顺序不变
Java String转JSONObject/JSONArray时保持顺序不变
Java String转JSONObject时保持顺序不变
|
7月前
|
SQL Java 关系型数据库
如何通过java程序获取表的自增主键值?
如何通过java程序获取表的自增主键值?
|
11月前
java202304java学习笔记第五十五天员工管理-JSONObject找不到
java202304java学习笔记第五十五天员工管理-JSONObject找不到
26 0
|
Java
Java——HashMap键值排序
Java——HashMap键值排序
379 0
|
JSON Java 数据格式
Java用Gson按照键值key排序json所有节点
Java用Gson按照键值key排序json所有节点
4316 0
java 读取excel内容转为JSONArray
需要引入的JAR      net.sourceforge.jexcelapi jxl 2.6.8 com.
1298 0
|
Java
关于 java JSONArray JSONObject转换问题
import lhy.client.json.JSONArray; import lhy.client.json.JSONException; import lhy.client.json.JSONObject; public class MyJson {public static void main(String[] args) throws JSONException {JSON
1517 0
|
Java 数据库连接 数据库
数据库同步和使用JSONObject让Java Bean“原地满状态复活”
    分类: 【java】2013-11-28 21:04 729人阅读 评论(0) 收藏 举报 简介我为什么写这样一个简单的问题呢?首先介绍一下项目背景。最近需要做一个数据库同步的工作,也就是一个Web程序有两个数据库,一个是它自身的本地数据库,另外一个是远程的数据库。
812 0