0

我有这个代码:

def fit(self,p1,p2,w):
    p=p1    
    m=self.bit(p,w)
    if p1.y!=p2.y:
        if m&0x30:
            p.y=w.y1 if m&0x10 else w.y2-1
            try:
                p.x=int((p.y-p2.y)*(p1.x-p2.x)/(p1.y-p2.y)+p2.x)
            except Exception,e:
                print e
                print p1.y!=p2.y        
                print p1.y,p2.y

输出是:

cannot convert float NaN to integer  
False  
199 199.0

我不知道为什么p1.y!=p2.y评估为 true,然后在异常中评估为 false

我正在运行 python 2.6.6

4

1 回答 1

1

你在分裂0/0

# (p.y-p2.y)*(p1.x-p2.x)
x = p.y - p2.y
x = 199 - 199.0 = 0
x1 = p1.x-p2.x
0 * x1 = 0* p1.x - 0* p2.x

这表示

(p.y-p2.y)*(p1.x-p2.x) = 0

现在我们通过这个设计 0:

#(p1.y-p2.y)
p1.y-p2.y
x = p.y - p2.y
x = 199 - 199.0 = 0

所以在这种情况下,你正在尝试做0/0

然后在整个事情的最后你尝试添加p2.x,我相信这就是为什么你得到错误cannot convert float NaN to integer而不是ZeroDivisionError: integer division or modulo by zero

它真的很容易解决。if p1.y!=p2.y:将第 4 行更改为If p1.y-p2.y != 0:

于 2011-04-11T08:01:44.417 回答