首页 > 解决方案 > 滑动窗口外的 for 循环范围

问题描述

我在列表中有一个范围(100 个字符串)。我想通过以给定的间隔选择 30 个字符串并将它们存储在一个列表中,在这个范围内迭代多次(比如 4 次)。但我也想将选择存储在 30 个字符串之外,并使用 pyspark 将它们存储在不同的列表中。

假设下面列表中的整数是字符串,示例代码:

t=[]
start=[10,20,50,70]
for i in start:
    windoww=i+30
    for j in range(i,windoww):
        t.append(j)

上面的代码为我提供了一个t范围为 10 到 99 的列表,其中指定了起始字符串start。我还想要一个在外面的列表t。所以对于第一次迭代,如果内容t

t= [10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39] 

我想要另一个清单说u

u=[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]

这在pyspark中可能吗?

我尝试创建一个从 [0 到 100] 调用的列表v并做了:

u=[stri for stri in v not in t] 

但是,我收到一个错误

'bool' 对象不可迭代

标签: pythonlistfor-looppyspark

解决方案


试试下面的功能

def Diff(li1, li2):
    return (list(list(set(li1)-set(li2)) + list(set(li2)-set(li1))))
 
li1 = [10, 15, 20]
li2 = [20, 15, 35]
  
li3 = Diff(li1, li2)
print(li3)

Output = [10,35] 

推荐阅读