我正在尝试过滤大量的元组,这些元组看起来就像这样:
tuple = ([], [('print', -108.0), ('denim', -144.0), ('floral', -158.0), ('summer', -172.0), ('chiffon', -217.0), ('crochet', -272.0), ('cotton', -275.0), ('graphic', -279.0), ('pattern', -281.0), ('sheer', -294.0)])我想要做的是创建一些代码行,我可以使用这些代码行告诉Python,我想检索一个包含字符串的列表,该字符串的数字大于-200,在这种情况下,我想获得:
list = ["print", "denim", "floral", "summer"]新部分:
现在感谢@Andrej,我有了解决这个问题的方法,但是如果我想做同样的事情,但是要做一个像这样的元组列表:
predictions = [([],
[('print', -72.0),
('summer', -141.0),
('chiffon', -157.0),
('floral', -266.0),
('graphic', -279.0),
('cotton', -279.0),
('denim', -282.0),
('cute', -321.0),
('striped', -331.0),
('pattern', -337.0)]),
([],
[('chiffon', -89.0),
('summer', -214.0),
('pleated', -250.0),
('sheer', -280.0),
('woven', -286.0),
('crochet', -293.0),
('solid', -295.0),
('cotton', -300.0),
('mesh', -316.0),
('party', -332.0)]),
([],
[('crochet', -188.0),
('chiffon', -204.0),
('summer', -209.0),
('floral', -209.0),
('pattern', -214.0),
('print', -233.0),
('cotton', -252.0),
('sheer', -282.0),
('elegant', -294.0),
('striped', -300.0)]),
(['striped'],
[('striped', 73.0),
('summer', -216.0),
('cotton', -252.0),
('chiffon', -287.0),
('denim', -299.0),
('print', -336.0),
('cute', -357.0),
('linen', -365.0),
('sheer', -372.0),
('chic', -385.0)]),
([],
[('summer', -146.0),
('crochet', -227.0),
('party', -233.0),
('cute', -251.0),
('mesh', -281.0),
('chiffon', -289.0),
('solid', -294.0),
('cotton', -301.0),
('floral', -322.0),
('beach', -323.0)]),
([],
[('cotton', -168.0),
('summer', -197.0),
('print', -211.0),
('striped', -227.0),
('graphic', -248.0),
('denim', -260.0),
('pattern', -302.0),
('floral', -336.0),
('solid', -341.0),
('cute', -341.0)]),
([],
[('print', -165.0),
('denim', -216.0),
('cotton', -260.0),
('striped', -262.0),
('graphic', -301.0),
('leather', -327.0),
('mesh', -339.0),
('stretch', -341.0),
('pattern', -346.0),
('summer', -347.0)]),
([],
[('crochet', -124.0),
('chiffon', -165.0),
('floral', -169.0),
('summer', -170.0),
('sheer', -227.0),
('party', -245.0),
('cute', -260.0),
('mesh', -286.0),
('elegant', -302.0),
('print', -308.0)])]如何创建一个列表列表,其中包含每个元组的列表,其中只显示数字大于-200的字符串?问题来自于图像识别模型的输出,我试图将@Andrej的代码嵌入到模型输出的for循环中:
predictions=[]
for x in df_images["Media"]:
p= predict(x, labels, model)
prediction = [i for lst in p for i, v in lst if v > -200]
predictions.append(prediction)但是它给了我一个错误:“太多的值不能打开(预期的2)”
发布于 2021-05-07 08:58:44
您可以使用列表理解:
tpl = (
[],
[
("print", -108.0),
("denim", -144.0),
("floral", -158.0),
("summer", -172.0),
("chiffon", -217.0),
("crochet", -272.0),
("cotton", -275.0),
("graphic", -279.0),
("pattern", -281.0),
("sheer", -294.0),
],
)
out = [i for lst in tpl for i, v in lst if v > -200]
print(out)指纹:
['print', 'denim', 'floral', 'summer']编辑:使用问题中的新列表predictions:
out = [[i for i, v in lst if v > -200] for _, lst in predictions]
print(out)指纹:
[['print', 'summer', 'chiffon'], ['chiffon'], ['crochet'], ['striped'], ['summer'], ['cotton', 'summer'], ['print'], ['crochet', 'chiffon', 'floral', 'summer']]https://stackoverflow.com/questions/67431876
复制相似问题