我遇到了与往常不太一样的列表理解。因此,我对列表压缩执行顺序感到困惑。
import re
folders = ['train_frames001', 'train_masks002',
'val_frames003','val_masks004', 'test_frames005', 'test_masks006']
folders.sort(key=lambda var:[int(x) if x.isdigit() else x
for x in re.findall(r'[^0-9]|[0-9]+', var)])
print(folders)
#Whether the list compresion part means
#for x in re.findall(r'[^0-9]|[0-9]+', var):
# if x.isdigit():
# int(x)
# else:
# x
我没有找到相关的样本和文档。
答案 0 :(得分:2)
我认为您对if-else
的顺序感到困惑。
a = [1,2,3,4,5,6,7,8]
如果您只是想简单地对每个数字进行平方运算
b = [i**2 for i in a]
# [1,4,9,16,25,36,49,64]
如果您要偶数(if
中的list-comprehension
语句)
c = [i for i in a if i%2==0]
# [2,4,6,8]
如果您只想对偶数进行平方(if-else
语句ternary operator
)
c = [i**2 if i%2==0 else i for i in a]
# [1,4,3,16,5,36,7,64]
答案 1 :(得分:0)
我运行代码,并得到time_in = (data['value'][index_3]['start_time'])
IndexError: list index out of range
,我认为结果是正确的。
如果要获得类似['test_frames005', 'test_masks006', 'train_frames001', 'train_masks002', 'val_frames003', 'val_masks004']
之类的结果,该结果按结束号排序。也许您应该像下面那样更改代码。
['train_frames001', 'train_masks002', 'val_frames003', 'val_masks004', 'test_frames005', 'test_masks006']