在嵌套列表中查找匹配项

时间:2016-07-13 10:01:31

标签: python matching

我正在尝试将项目列表与另一个不同维度的项目列表进行匹配,并在项目匹配时从第二个列表中打印元素。例如:

stlist=['6', '3', '4', '2', '5', '1']
ndlist=[['Tom', '1'], ['Joh', '2'], ['Sam', '3'], ['Tommy','4'], ['Nanni', '5'], ['Ron', '6']]

我的输出列表按照我的stlist的升序生成名称。 即Tom,Joh,Sam,Tommy,Nanni,Ron但我希望outputlist与stlist的顺序相同。

我的Python代码是:

for sublist in ndlist:
    for element in stlist:
        if element in sublist[1]:
            print(sublist[0])

上面代码显示的输出列表是:Tom,Joh,Sam,Tommy,Nanni,Ron而不是

outputlist = [Ron, Sam, Tommy, Joh, Nanni, Tom]

所以它实际上按升序排序我的1stlist并按顺序打印第二个列表中的名称。但是如果我的stlist按升序排列,那么输出列表就可以了。

任何人都可以告诉我为什么请,我应该如何修改代码以获得我想要的输出列表。

3 个答案:

答案 0 :(得分:2)

尝试重新排列for循环:

for element in stlist:
    for sublist in ndlist:
        if element in sublist[1]:
            print (sublist[0])

此外,if语句应该是这样的:if element == sublist[1]:或者在某个ndlist元素中找到元素“1”,如下所示:['foo', '10']

此外,对于大型列表,此解决方案效率最高。为了提高效率,您可以尝试对ndlist进行排序并执行二进制搜索以检查元素是否存在。

答案 1 :(得分:1)

您可以使用sorted和自定义排序键(Lambda函数)来执行此操作:

>>> [i[0] for i in sorted(ndlist, key = lambda x:stlist.index(x[1]))]
['Ron', 'Sam', 'Tommy', 'Joh', 'Nanni', 'Tom']

这行代码使用ndlist中数字的位置作为排序键对stlist进行排序,然后列表推导构建一个仅包含名称的新列表。

答案 2 :(得分:0)

除了嵌套循环或排序之外,您还可以通过ndlist创建一个线性运行的映射,然后使用另一个线性运行stlist来构建结果列表:

mapping = dict((b, a) for a, b in ndlist)
result = [mapping[x] for x in stlist]
print(result)