zoukankan      html  css  js  c++  java
  • java 把json对象中转成map键值对

      相关:Json对象与Json字符串的转化、JSON字符串与Java对象的转换

      本文的目的是把json串转成map键值对存储,而且只存储叶节点的数据

      比如json数据如下:

      {responseHeader:{status:0,QTime:0},spellcheck:{suggestions:{中国:{numFound:9,startOffset:0,endOffset:2,suggestion:[中国工商银行, 中国人民, 中国国际, 中国农业, 中国市场, 中国经济, 中国人, 中国广播, 中国文化]}},collations:{collation:中国工商银行}}}

      如果存储在键值对中,变成如下:

      

      这样通过map,可以直接获取对应键的数据。具体代码如下:

    import org.apache.solr.client.solrj.SolrServerException;
    
    import org.json.*;
    
    import java.io.IOException;
    import java.util.*;
    
    /**
     * @Author:sks
     * @Description:
     * @Date:Created in 16:18 2017/12/18
     * @Modified by:
     **/
    public class JsontoMap {
    
        /**
         * @Author:sks
         * @Description:把json对象数据存储在map以键值对的形式存储,只存储叶节点
         * @Date:
         */
        private static void JsonToMap(Stack<JSONObject> stObj, Map<String, Object> resultMap)  throws SolrServerException, IOException {
    
            if(stObj == null && stObj.pop() == null){
                return ;
            }
            JSONObject json = stObj.pop();
            Iterator it = json.keys();
            while(it.hasNext()){
                String key = (String) it.next();
                //得到value的值
                Object value = json.get(key);
                //System.out.println(value);
                if(value instanceof JSONObject)
                {
                    stObj.push((JSONObject)value);
                    //递归遍历
                    JsonToMap(stObj,resultMap);
                }
                else {
                    resultMap.put(key, value);
                }
            }
        }
        public static void main(String []args) throws SolrServerException, IOException{
            String jsonStr ="{responseHeader:{status:0,QTime:0},spellcheck:{suggestions:{中国:{numFound:9,startOffset:0,endOffset:2," +
                    "suggestion:[中国工商银行, 中国人民, 中国国际, 中国农业, 中国市场, 中国经济, 中国人, 中国广播, 中国文化]}}," +
                    "collations:{collation:中国工商银行}}}";
            JSONObject obj = new JSONObject(jsonStr);
            Stack<JSONObject> stObj = new Stack<JSONObject>();
            stObj.push(obj);
            Map<String, Object> resultMap =new HashMap<String, Object>();
            JsonToMap(stObj,resultMap);
            Set<String> keys = resultMap.keySet();
            for (String key:keys){
                System.out.println(key+":"+resultMap.get(key));
            }
    
        }
    //    输出:
    //    endOffset:2
    //    startOffset:0
    //    QTime:0
    //    numFound:9
    //    suggestion:["中国工商银行","中国人民","中国国际","中国农业","中国市场","中国经济","中国人","中国广播","中国文化"]
    //    collation:中国工商银行
    //    status:0
    
    }

       

      

  • 相关阅读:
    Zabbix客户端日志出现(Not all processes could be identified, 解决
    zabbix 本地编译安装
    redis 配置文件解释 以及集群部署
    Unix shell范例精解 课后题
    if __name__ == '__main__':用法
    爬取猫眼电影100榜单 代码
    CentOS编译安装软件过程中遇到zlib.h: No such file or directory
    Codeigniter添加Composer支持
    CodeIgniter composer.json安装第三类库操作
    使用composer命令加载vendor中的第三方类库 的方法
  • 原文地址:https://www.cnblogs.com/shaosks/p/8058336.html
Copyright © 2011-2022 走看看