问题描述
我试图在 python 中的嵌套列表理解语句中放置一个嵌套条件,但我不确定我缺少什么会使它成为可能,正常循环和条件看起来像这样
while(fscanf(fin,"%lf %lf %lf",&lat,&longitude,&skip) != EOF) {
double buf[3] = {lat,long,skip};
write(fd,buf,sizeof(double)*3);
}
我通过列表理解得到的是这个
newarr = []
for i in array1:
for x in array2:
if x.find(i) !=-1:
if i not in newarr:
newarr.append(i)
解决方法
您可以在列表推导式中放置多个 for
子句,并且在计算实际值或检查条件之前,它们将按照从左到右的顺序进行计算,就好像它们是嵌套的一样。
newarr = list(set(i for i in array1 for x in array2 if x.find(i) != -1))
使用 set()
作为 if i not in newarr
检查的替代,这不可能在列表推导式中表示,因为列表 newarr
尚未完全构建。相反,这将省略输出中的重复项(出于排序的目的,最后一次出现将优先)。
如果您想保留第一次出现而不是最后一次出现,请尝试执行 list(reversed(set(i for i in reversed(array1) ...)))
。