JSON数组转LIST集合的两种方法

需求介绍

	JSON字符串中包含多个集合,例如[{"a1":111,"a2":112,"a3":113},{"a1":"211","a2":"212","a3":"213"}........],现在后台获取到一个参数b,如果b=111,那么需要将{"a1":111,"a2":112,"a3":113}这组信息取出来后返回。

需求分析

	首先想到的是第一种方法,需要创建实体类,将数据信息取出来放进实体类中,然后再进行遍历取值。

创建实体类的转换方法

实体类(payTermInfo)创建略

public Map<String,String> getUnionPayTermInfo(String orgCode,Integer amount){

        if(StringUtils.isEmpty(orgCode)) return null;

        Parameter parameter =parameterService.findByNameWithCache(RedisKey.TermInfo);
        if(StringUtils.isEmpty(parameter.getParameterValue())){
            logger.info("终端信息未配置");
            return null;
        }

        Map<String, String> map = new HashMap<>();
        //判断用户是否可以参加活动
        try{
            List<payTermInfo> list = JSON.parseArray(parameter.getParameterValue(),payTermInfo.class);
            for(payTermInfo t : list){
                if(orgCode.equals(t.getProvince_code())){
                    if(t.getEnable().equals(0)){
                        if(amount >= Integer.valueOf(t.getMinAmount()) && amount < Integer.valueOf(t.getMaxAmount())){
                            logger.info("用户可以参加活动");
                            //经度 维度 终端入网认证编号 终端设备类型 终端序列号 加密随机因子 密文数据 应用程序版本号
                            map.put("longitude",t.getLongitude());
                            map.put("latitude",t.getLatitude());
                            map.put("networkLicense",t.getNetworkLicense());
                            map.put("deviceType",t.getTermDeviceType());
                            map.put("serialNum",t.getSerialNum());
                            map.put("encryptRandNum",t.getEncryptRandNum());
                            map.put("secretText",t.getSecretText());
                            map.put("appVersion",t.getAppVersion());
                            map.put("TermId",t.getTermId());
                        }
                    }
                }
            }
        }catch (Exception e){
            logger.info("Json转换失败");
            return null;
        }
        return map;
    }

但是这种方法也有缺点,第一,需要创建实体,并且需要在数据库中创建表,与实体字段对应。第二,JSON数据已经保存在缓存里了,再拿出来存放进数据库中再取出来,相当麻烦。所以第一次代码提交后被打了回来,那么第二种,利用JSONArray。

利用JSONArray遍历数组

public Map<String,String> getUnionPayTermInfo(String orgCode,Integer amount){

        if(StringUtils.isEmpty(orgCode)) return null;

        Parameter parameter =parameterService.findByNameWithCache(RedisKey.TermInfo);
        if(StringUtils.isEmpty(parameter.getParameterValue())){
            logger.info("终端信息未配置");
            return null;
        }

        Map<String, String> map = new HashMap<>();
        //判断用户是否可以参加活动
        try{
            //将json数据转换为json数组
            JSONArray jsonArray = JSONArray.parseArray(parameter.getParameterValue());
            //将jsonArray中的数组放进map中然后进行遍历,获取map的键值对信息
            List<Map> list =jsonArray.toJavaList(Map.class);
            for(Map map1 : list){
                if(map1.get("province_code").equals(orgCode)){
                    //enable为0是可以参加活动
                    if(map1.get("enable").equals(0)){
                        if(StringUtils.isEmpty(map1.get("MinAmount")) || StringUtils.isEmpty(map1.get("MaxAmount"))
                                || map1.get("MinAmount").equals("0") ||map1.get("MaxAmount").equals("0")){
                            //经度 维度 终端入网认证编号 终端设备类型 终端序列号 加密随机因子 密文数据 应用程序版本号
                            map.put("longitude", String.valueOf(map1.get("Longitude")));
                            map.put("latitude", String.valueOf(map1.get("Latitude")));
                            map.put("networkLicense", String.valueOf(map1.get("NetworkLicense")));
                            map.put("deviceType", String.valueOf(map1.get("TermDeviceType")));
                            map.put("serialNum", String.valueOf(map1.get("SerialNum")));
                            map.put("encryptRandNum", String.valueOf(map1.get("EncryptRandNum")));
                            map.put("secretText", String.valueOf(map1.get("SecretText")));
                            map.put("appVersion", String.valueOf(map1.get("AppVersion")));
                            map.put("TermId", String.valueOf(map1.get("TermId")));
                        } else if(amount >= (int) map1.get("MinAmount") && amount < (int)map1.get("MaxAmount")){
                            logger.info("用户可以参加活动");
                            //经度 维度 终端入网认证编号 终端设备类型 终端序列号 加密随机因子 密文数据 应用程序版本号
                            map.put("longitude", String.valueOf(map1.get("Longitude")));
                            map.put("latitude", String.valueOf(map1.get("Latitude")));
                            map.put("networkLicense", String.valueOf(map1.get("NetworkLicense")));
                            map.put("deviceType", String.valueOf(map1.get("TermDeviceType")));
                            map.put("serialNum", String.valueOf(map1.get("SerialNum")));
                            map.put("encryptRandNum", String.valueOf(map1.get("EncryptRandNum")));
                            map.put("secretText", String.valueOf(map1.get("SecretText")));
                            map.put("appVersion", String.valueOf(map1.get("AppVersion")));
                            map.put("TermId", String.valueOf(map1.get("TermId")));
                        }
                    }
                }
            }
        }catch (Exception e){
            logger.info("Json转换失败");
            return null;
        }
        return map;
    }

END

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中可以使用`JSONObject`类来操作JSON对象,对于JSON对象的属性排序可以通过以下步骤实现: 1. 将JSON对象的属性名存储到一个List中; 2. 对List进行排序,可以使用`Collections.sort`方法并自定义比较器; 3. 遍历排序后的List,根据属性名获取JSON对象的属性值,并重新生成JSON对象。 代码示例: ```java JSONObject jsonObj = new JSONObject("{\"name\":\"Tom\",\"age\":20,\"city\":\"Beijing\"}"); List<String> keys = new ArrayList<String>(jsonObj.keySet()); Collections.sort(keys); JSONObject sortedJsonObj = new JSONObject(); for (String key : keys) { sortedJsonObj.put(key, jsonObj.get(key)); } System.out.println(sortedJsonObj.toString()); ``` 对于Java对象集合或对象数组的排序,可以使用`Collections.sort`或`Arrays.sort`方法,并自定义比较器。比较器可以实现`Comparator`接口,重写`compare`方法。 代码示例: ```java List<Person> personList = new ArrayList<Person>(); personList.add(new Person("Tom", 20)); personList.add(new Person("Alice", 18)); personList.add(new Person("Bob", 22)); Collections.sort(personList, new Comparator<Person>() { public int compare(Person p1, Person p2) { return p1.getAge() - p2.getAge(); } }); for (Person person : personList) { System.out.println(person.getName() + " " + person.getAge()); } ``` ```java Person[] personArray = new Person[] { new Person("Tom", 20), new Person("Alice", 18), new Person("Bob", 22) }; Arrays.sort(personArray, new Comparator<Person>() { public int compare(Person p1, Person p2) { return p1.getAge() - p2.getAge(); } }); for (Person person : personArray) { System.out.println(person.getName() + " " + person.getAge()); } ``` 其中,`Person`类的定义如下: ```java class Person { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值