嵌套列表理解中的嵌套条件

问题描述

我试图在 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) ...)))

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...