关于python里面编写杨辉三角的一个小小的问题

def triangles():

ret = [1]

while True:

    yield ret

    for i in range(1, len(ret)):

        **ret[i] = j[i] + j[i - 1]**

    ret.append(1)

    j = ret[:]

#以上list j定义在被调用后面,那前面那个调用(已加星号表示)是如何完成的

ret是当前的行,j是上一行,它由上次迭代的ret得来( j = ret[:])
杨辉三角
1
1 1
1 2 1
1 3 3 1
14 6 4 1
...
因此ret和j(下面一行和上面一行相比),ret[0]=1,ret[i] = j[i] + j[j - 1],也就是比如说4 = 3 + 1,6= 3+3,...
最后再append一个1