Map<String, Map<String, String>>转String,再转回Map

import org.junit.Test;

import java.util.*;
import java.util.regex.Pattern;

/**
 *
 */
public class Test2 {

    @Test
    public void test() {
        Map<String, String> testMap1 = new HashMap<String, String>();
        testMap1.put("key1", "val1");
        testMap1.put("key2", "val2");

        Map<String, String> testMap2 = new HashMap<String, String>();
        testMap2.put("key21", "val21");
        Map<String, Map<String, String>> testMapMap1 = new HashMap<String, Map<String, String>>();
        testMapMap1.put("key1", testMap1);
        testMapMap1.put("key2", testMap2);

        System.out.println(map2String(testMapMap1));
        System.out.println(mapString2Map(map2String(testMapMap1)));
    }


    public static String map2String(Map map){
        java.util.Map.Entry entry;
        StringBuffer sb = new StringBuffer();
        for(Iterator iterator = map.entrySet().iterator(); iterator.hasNext();)
        {
            entry = (java.util.Map.Entry)iterator.next();
            sb.append(entry.getKey().toString()).append( "'" ).append(null==entry.getValue()?"":
                    entry.getValue().toString().substring(1, entry.getValue().toString().length() - 1)).append (iterator.hasNext() ? "^" : "");
        }
        return sb.toString();
    }

    public static Map mapString2Map(String mapString){
        Map map = new HashMap();
        java.util.StringTokenizer items;
        for(StringTokenizer entrys = new StringTokenizer(mapString, "^"); entrys.hasMoreTokens();
            map.put(items.nextToken(), items.hasMoreTokens() ? (mapStringToMap((String) (items.nextToken()))) : null))
            items = new StringTokenizer(entrys.nextToken(), "'");
        return map;
    }

    public static Map mapStringToMap(String text){
        HashMap<String,String> data = new HashMap<String,String>();
        Pattern p = Pattern.compile("[\\{\\}\\=\\, ]++");
        String[] split = p.split(text);
        for ( int i=0; i+2 <= split.length; i+=2 ){
            data.put( split[i], split[i+1] );
        }
        return data;
    }

}

参考:http://blog.csdn.net/ziwen00/article/details/7976144

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值