我有以下列表:
val list1 = List(
(List("pune"),"myname1","myId1", "myAdd1"),
(List("pune"),"myname2","myId2", "myAdd1"),
(List("pune"),"myname3","myId3", "myAdd3"),
(List("mumbai"),"myname2","myId1", "myAdd2")
)
val list2 = List(
("pune","myAdd1"),
("mumbai","myAdd2")
)
我想要关注输出 -
List(
(List(pune),"myname1","myId1", "myAdd1"),
(List(pune),"myname2","myId2", "myAdd1"),
(List("mumbai"),"myname2","myId1", "myAdd2")
)
如何使用scala获得以上输出?
答案 0 :(得分:0)
我仍然不确定你想要什么,但我认为使用list2
按元组中的第一个和第四个字段过滤list1
?
val list1 = List(
(List("a1"), "b1", "c1", "d1"),
(List("a1"), "b2", "c2", "d1"),
(List("a1"), "b3", "c3", "d3"),
(List("a2"), "b2", "c1", "d2")
)
val list2 = List(
("a1", "d1"),
("a2", "d2")
)
list1.filter({
case (a::Nil, b, c, d) =>
list2.contains((a, d))
case _ =>
false
})
/*
Result:
List(
(List(a1),b1,c1,d1),
(List(a1),b2,c2,d1),
(List(a2),b2,c1,d2)
)
*/
答案 1 :(得分:0)
val list1 = List(
(List("pune"),"myname1","myId1", "myAdd1"),
(List("pune"),"myname2","myId2", "myAdd1"),
(List("pune"),"myname3","myId3", "myAdd3"),
(List("mumbai"),"myname2","myId1", "myAdd2"))
val list2 = List(("pune","myAdd1"),("mumbai","myAdd2"))
list1.filter(x=> list2 contains ((x._1(0), x._4)))
// List((List(pune),myname1,myId1,myAdd1),
// (List(pune),myname2,myId2,myAdd1),
// (List(mumbai),myname2,myId1,myAdd2))
但实际上,这只是您之前提出的几个问题的一个小变化。我希望你能从其他答案中学到足够的东西,以便能够自己解决这类问题。