[英]can someone please explain this line of code?
它的想法是從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)
謝謝!
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)
測試名稱的所有字母是沒有用的。 一種有效的方法是僅將第一個字母與集合匹配:
[name for name in nombres
if name[0].upper() in set(padron)]
輸出:
['Tamara',
'Juan',
'Alberto',
'Exequiel',
'Alejandro',
'Antonio',
'Antonia',
'Amalia',
'Jorgelina',
'Anabela']
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.