我有一个列表,每个元素都是一个数组数组。像这样:
contourList = [ [ [x0,y0],[x1,y1]...] ,[ [x2,y2],[x3,y3] ]...]
每个列表元素都是一个表示x-y维度轮廓的坐标数组,每个坐标都是一个表示x,y值的长度为2的数组。
现在,我要检查此列表中是否存在给定的轮廓“数组数组”,如果是,则将其删除。当我这样做时,我得到一个错误:
contourList.remove(contour)
ValueError: The truth value of an array with more than one element is ambiguous. Use a.any() or a.all()
这是代码:
for contour in contourList:
if equalCoords(contour, mycontour):
contourList.remove(contour)
我使用这种方法“ equalCoords来检查两个轮廓是否相同。它是:
def equalCoords(contourA,contourB):
if len(contourA)!=len(cylinderB):
return False
else:
for contourCoordA,contourCoordB in zip(contourA,contourB):
if contourCoordA[0]!=contourCoordB[0] or contourCoordA[1]!=contourCoordB[1]:
return False
return True
这是轮廓的示例:
[[ 240.0696526 413. ]
[ 241. 412.31021016]
[ 241.57079161 412. ]
[ 242. 411.77849971]
[ 243. 411.41933059]
[ 244. 411.21092001]
[ 245. 411.13343726]
[ 246. 411.1804759 ]
[ 247. 411.35514159]
[ 248. 411.6721164 ]
[ 248.68715031 412. ]
[ 249. 412.15537894]
[ 250. 412.82438379]
[ 250.20954831 413. ]]
该代码可以正常工作并成功删除了某些轮廓,但是在某些迭代之后,它停止并给出了我上面提到的错误。
如果我的问题还不够清楚,请告诉我。
最佳答案
我想问题是当您执行remove
时,它会寻找等于contour
的项目,但是contour
是一个列表,并且它会检查内部list1==list2
是否导致此错误。因此,您可以改用pop
或使用列表推导。
你可以做:
i = 0
while i < len(contourList):
if equalCoords(contourList[i], mycontour):
contourList.pop(i)
else:
i += 1
要么:
contourList = [c for c in contourList if not equalCoords(c, mycontour)]
要么:
contourList = filter(lambda c: not equalCoords(c, mycontour), contourList)
关于python - 为什么在尝试从列表中删除数组时出现此错误?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/35416015/