Rak*_*ain 1 scala scala-collections
我有以下两个清单 -
list1 = List(("jira","ABC"),
("collApp","ABC"),
("amarColl","ABC"),
("Ubuntu1404","PQR"),
("relColAdmin","XYZ"))
list2 = List(("Linux_server","Hyper-V","suseLinux"),
("Linux_server","VmWare","collApp"),
("Linux_server","VmWare","relColAdmin"),
("Linux_server","VmWare","amarColl"),
("Linux_server","Hyper-V","ubuntu1310"))
Run Code Online (Sandbox Code Playgroud)
从上面的两个列表我想检查第二个列表是否包含list1的每个元素(元组)的第一个值,如果匹配则在list2中插入第二个值,否则在list2中插入空值.
这是样本输出 -
output = List(("Linux_server","Hyper-V","suseLinux",""),
("Linux_server","VmWare","collApp","ABC"),
("Linux_server","VmWare","relColAdmin","XYZ"),
("Linux_server","VmWare","amarColl","ABC"),
("Linux_server","Hyper-V","ubuntu1310",""))
Run Code Online (Sandbox Code Playgroud)
list1已经处于完美的形式,可以变成地图.我们将其转换为默认值为""的地图.因此,如果我们从地图中请求一个不存在的密钥,我们就会回来""
scala> val map1 = list1.toMap.withDefaultValue("")
map1: scala.collection.immutable.Map[String,String] =
Map(amarColl -> ABC, Ubuntu1404 -> PQR, relColAdmin -> XYZ,
jira -> ABC, collApp -> ABC)
Run Code Online (Sandbox Code Playgroud)
现在我们所要做的就是将3元组映射到4元组:
scala> list2.map { case (a,b,c) => (a,b,c,map1(c)) }
res0: List[(String, String, String, String)] =
List((Linux_server,Hyper-V,suseLinux,""),
(Linux_server,VmWare,collApp,ABC),
(Linux_server,VmWare,relColAdmin,XYZ),
(Linux_server,VmWare,amarColl,ABC),
(Linux_server,Hyper-V,ubuntu1310,""))
Run Code Online (Sandbox Code Playgroud)