我有一个这样的清单:
MyList = [2,3,(1,2),5]
其中元素0,1和3是整数,而元素2是元组。我想创建一个计数器,告诉我在元组到来之前列表中有多少元素。 在这个例子中,我想要一个计数器,它将取值2(2个元素,2和3,在第一个元组之前)。我尝试过以下方法:
counter = 0
while MyList[counter] is not tuple:
counter = counter + 1
但它不起作用,因为当它评估语句“(1,2)不是元组”而不是提高False时它继续取值True。知道问题可能是什么以及如何解决问题?谢谢。
答案 0 :(得分:10)
您可以使用for
循环和break
输出:
counter = 0
for elem in MyList:
if isinstance(elem, tuple):
break
counter += 1
或使用enumerate()
:
for counter, elem in enumerate(MyList):
if isinstance(elem, tuple):
break
# counter *could* be unbound if `MyList` is empty
或者您可以使用itertools.takewhile()
:
from itertools import takewhile
counter = sum(1 for elem in takewhile(lambda e: not isinstance(e, tuple), MyList))
后一种方法的演示:
>>> from itertools import takewhile
>>> MyList = [2,3,(1,2),5]
>>> sum(1 for elem in takewhile(lambda e: not isinstance(e, tuple), MyList))
2
答案 1 :(得分:8)
使用isinstance()
确定对象的类型:
>>> counter = 0
>>> while not isinstance(MyList[counter], tuple):
... counter += 1
...
>>> counter
2
答案 2 :(得分:6)
只需使用发电机。它是最简单的。
next(index for index, elem in enumerate(MyList) if isinstance(elem, tuple))
答案 3 :(得分:3)
for i, e in enumerate([2,3,(1,2),5]):
if isinstance(e, tuple):
break
print i
实际上,这是find()
用例的又一个示例。不幸的是,Python不提供开箱即用的功能。有了它,它将只是:
return find(lambda e: isinstance(e, tuple), [2,3,(1,2),5])
答案 4 :(得分:1)
cnt = 0
elem = MyList[cnt]
while isinstance(elem, int):
cnt+= 1
elem = MyList[cnt]
return cnt
答案 5 :(得分:0)
另一种(可能更简单)的方法是:
MyList = [2,3,(1,2),5]
counter=0
for i in MyList:
if type(i) == tuple:
break
counter+=1
print(counter)