1. 程式人生 > >map集合的keySet,entrySet,cotainsKey,put方法的遍歷Map集合及字串的split運用

map集合的keySet,entrySet,cotainsKey,put方法的遍歷Map集合及字串的split運用

    有下列字串:
        "銷售:張三;財務:李四;銷售:王五;財務:趙六;程式:mike;程式:jerry;美工:jackson;前端:green;前端:nick;程式:錢七;銷售:alice"  
    思考:
        將字串按照;拆分的結果就是一個map資料 Map<String, String>輸出最終的map資料    
        分析上述字串然後統計每個職位總共多少人?   
        使用Map儲存統計的結果,其中key:職位, value為該職位人數;
        然後分別輸出各職位的名稱( keyset),各職位人數(entryset)
程式碼:

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

public class TestDemo1 {
	public static void main(String[] args) {
		Map<String, String> map = new HashMap<String,String>();
		String str = 
				"銷售:張三;財務:李四;銷售:王五;財務:趙六;程式:mike;程式:jerry;美工:jackson;前端:green;前端:nick;程式:錢七;銷售:alice";
		String[] strs = str.split(";");
		
		Map<String,Integer> map1 = new HashMap<String,Integer>();
		for(int i=0;i<strs.length;i++){
			int index = strs[i].indexOf(":");
			String str1 = strs[i].substring(0, index);
			String str2 = strs[i].substring(index+1);
			map.put(str1, str2);
			if(map1.containsKey(str1)) {
				map1.put(str1 , map1.get(str1)+1);
			}else {
				map1.put(str1, 1);
			}
		}
		System.out.println(map);
		
		Set<String> set = map1.keySet();
		System.out.println(set);
		Set<Entry<String,Integer>> s = map1.entrySet();
		System.out.println(s);
		}
}

結果:
{美工=jackson, 前端=nick, 程式=錢七, 銷售=alice, 財務=趙六}
[美工, 前端, 程式, 銷售, 財務]
[美工=1, 前端=2, 程式=3, 銷售=3, 財務=2]