它的想法是從nombres那個開頭的任何字母開始,padron并將其保存到nombres_filtrados(我無法理解)中,我將非常感謝您的幫助!
padron = ['A', 'E', 'J', 'T']
nombres = ['Tamara', 'Marcelo', 'Martin', 'Juan', 'Alberto', 'Exequiel',
'Alejandro', 'Leonel', 'Antonio', 'Omar', 'Antonia', 'Amalia',
'Daniela', 'Sofia', 'Celeste', 'Ramon', 'Jorgelina', 'Anabela', "X"]
nombres_filtrados = [x for x in nombres if any(f in x for f in padron)]
print(nombres_filtrados)
謝謝!
uj5u.com熱心網友回復:
nombres_filtrados 根據您的 padron 串列檢查每個名稱中的每個字母,實際上它應該是:
padron = ['A', 'E', 'J', 'T']
nombres = ['Tamara', 'Marcelo', 'Martin', 'Juan', 'Alberto', 'Exequiel',
'Alejandro', 'Leonel', 'Antonio', 'Omar', 'Antonia', 'Amalia',
'Daniela', 'Sofia', 'Celeste', 'Ramon', 'Jorgelina', 'Anabela', "X",'eA']
nombres_filtrados = [x for x in nombres if any(f in x[0] for f in padron)]
print(nombres_filtrados)
基本上 nombres_filtrados 正在做的是:
padron = ['A', 'E', 'J', 'T']
nombres = ['Tamara', 'Marcelo', 'Martin', 'Juan', 'Alberto', 'Exequiel',
'Alejandro', 'Leonel', 'Antonio', 'Omar', 'Antonia', 'Amalia',
'Daniela', 'Sofia', 'Celeste', 'Ramon', 'Jorgelina', 'Anabela', "X",'eA']
nombres_filtrados = [x for x in nombres if any(f in x[0] for f in padron)]
output = []
for name in nombres: #For Each Name in Nombres
if name[0] in padron: #if the First Letter is In Padron
output.append(name) #Save To Our Output
print(output)
uj5u.com熱心網友回復:
測驗名稱的所有字母是沒有用的。一種有效的方法是僅將第一個字母與集合匹配:
[name for name in nombres
if name[0].upper() in set(padron)]
輸出:
['Tamara',
'Juan',
'Alberto',
'Exequiel',
'Alejandro',
'Antonio',
'Antonia',
'Amalia',
'Jorgelina',
'Anabela']
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/340813.html
