在这里,我正在尝试解决顺序问题。我正在从输入中进行1:1模型混合序列。示例:
[sw,cr,dw,sw]
我在这里附加了我的代码。我有一个错误。我找不到。
sw = ['1','4','5','8']
dw = ['3','7']
cr = ['2','6']
#sample output = ['sw 1','dw 1','c 1']
max_item = [len(sw),len(dw),len(cr)]
a=0
b=0
c=0
flag_sw = True
flag_dw = True
flag_cr = True
for i in range(max(max_item)):
if (flag_sw)|(flag_dw)|(flag_cr)== False:
break
# Single Weld
try:
print(i,"i--swI #",sw[i+a])
a +=1
except:
flag_sw = False
print("--empty---swI #")
try:
print(i,"i---crI #",cr[i+c])
c +=1
except:
try:
print(i,"i---dwI #",dw[i+b])
b +=1
except:
flag_dw = False
print("---dw array Empty dwI #")
# Ceramic
try:
print(i,"i---crII #",cr[i+c])
c +=1
except:
flag_cr = False
print("---empty crII #")
try:
print(i,"i---swII #",sw[i+a])
a +=1
except:
print("--- empty SWII---")
try:
print(i,"i---dwII #",dw[i+b])
b +=1
except:
flag_dw = False
print("--- empty dwII---")
# Double Weld
try:
print(i,"i--dwI3 #",dw[i+b])
b +=1
except:
print(i,"i--empty---dwI3 #")
b +=1
try:
print(i,"i---crI3 #",cr[i+c])
c +=1
except:
try:
print(i,"i---saI3 #", sw[i+a])
a +=1
except:
print("--empty-swI3 #")
# Again Single Weld
try:
#if flag_sw & flag_dw == False:
# a +=1
print(i,"i-- repeat swI4 #",sw[i+a])
except:
try:
#if flag_sw & flag_dw == False:
# c +=1
print(i,"i--repeat crI4 #",cr[i+c])
except:
try:
#if flag_sw & flag_c == False:
# b +=1
print(i,"i--repeat----dwI4 #",dw[i+b])
except:
print("---empty repeat dwI4 #")
print(" -- cycle ending {}--".format(i))
print("")
我正在尝试获得
之类的输出1,2,3,4
5,6,7,8
但是序列6 and 7
丢失了。
我当前的输出是
1,2,3,4
5,8
谁能告诉我我哪里出问题了?
答案 0 :(得分:1)
不确定我是否正确理解了这个问题。老实说,您的代码没有太大意义。
max(max_items)
次,尽管假设每个组至少使用一次,它显然最多只能重复min(max_items)
次if flag_sw | flag_dw | flag_cr == False: break
仅在所有这些标记均为False
try/except
结构块中,您从不同的组中获取三个项,而不仅仅是上面的注释中建议的 1) sw[i+a]
,dw[i+b]
和cr[i+c]
而不是sw[a]
,dw[b]
和cr[c]
必然会导致索引错误随着i
的增加相反,您可以使用iter
为不同的列表创建迭代器,然后根据所需的模式从这些迭代器中获取next
元素。
>>> isw, idw, icr = map(iter, (sw, dw, cr))
>>> num = len(sw) // 2
>>> [[next(isw), next(icr), next(idw), next(isw)] for _ in range(num)]
[['1', '2', '3', '4'], ['5', '6', '7', '8']]
这是假设sw
,dw
和cr
中有足够的元素,并且没有任何迭代器会为时过早。如果是这种情况,您可以使用next(icr, None)
,然后从结果中过滤出None
元素,但目前尚不清楚这种情况下代码的行为。
1)如果我正确理解嵌套的try/except
,如果cr
为空,则想从sw
获取下一项,对于其他。在这种情况下,可以通过定义一个辅助函数,尝试从多个next
对象中获取iter
元素,使代码更加紧凑。
def get_next(*iterators):
for it in iterators:
try:
return next(it)
except StopIteration:
pass
isw, idw, icr = map(iter, (sw, dw, cr))
while True:
a = get_next(isw, icr, idw)
b = get_next(icr, isw, idw)
c = get_next(idw, isw, icr)
d = get_next(isw, icr, idw)
if not any([a, b, c, d]):
break
print([x for x in (a, b, c, d) if x is not None])
如果列表中的项目数量不匹配,这也将起作用。