我有两个列表,其中列表A的元素包含在列表B的元素中。注意,这个例子中顺序比较重要。
A = ['pent', 'tri', 'rec', 'oct', 'hex']
B = ['triangle', 'rectangle', 'pentangle', 'hexagon', 'octagon']
我想遍历A和B,无论在B中找到A的位置,都将其添加到字典中,然后再将其添加到另一个字典中。
d = {'prefix': a, 'shape':b}
l = [{'prefix': 'pent', 'shape':'pentangle'}, {'prefix':'tri' , 'shape':'triangle'}, {'prefix': 'rec', 'shape':'rectangle'},...]
我尝试使用zip函数,但由于B相对于A是无序的,所以它不起作用。
dict_list = []
for i,j in zip(A,B):
if i in j:
d = {'prefix': i, 'shape':j}
dict_list.append(d)
我知道可以像“for i in A if i in B”这样做,但是我不知道如何将匹配的值放入我的字典中。
我认为这是一个非常基本的问题,我只是无法使它起作用。使用zip应该可以解决这个问题吗?我想也可能预先填充前缀,然后以某种方式使用它来查找形状,但是我不确定语法。我使用的列表在某些情况下有1000多个记录,因此无法手动执行此操作。
编辑:在我的示例中犯了一个错误:我正在使用的实际列表和字符串并非全部使用前缀。我不确定是否可以将其他方法替换为这些答案,但我感谢所有回答。我要解析的字符串是URL和URL的部分。 因此,A中充满了类似于'NA1234'
的字符串,B则是'www.oops/NA1244/betterexample'
。
B
中是否可能有多个元素具有A
中的前缀?例如B = ['octagon', 'octahedron']
。 - wjandreaset(['octagon','octahedron']) == {'octagon','octahedron'}
。 - wjandrea