簡體   English   中英

python中的if語句后變量重置為0

[英]Variable resetting back to 0 after if statement in python

我收到此錯誤

IndexError:列表索引超出范圍

從我收集的數據來看,這是因為我的r變量一旦進入if語句,就會立即重置為0。 我正在學習python,因此任何提示和技巧將不勝感激。

這是我的代碼

import sys
from test.test_email.test_message import first
def initMatrix(B,D,seq1,seq2,gap,match,miss): 
    r=0
    c=0
    numRows=0
    numCols=0
    temp=1
    numRows=len(seq1)+1
    numCols=len(seq2)+1
    B[0][0]= 0
    D[0][0]='0'
    for r in range(numRows):
        B[r][0]=temp*gap
        temp+=temp
        D[r][0]='V'
    temp=1
    for c in range(numCols):
        B[0][c]=temp*gap
        temp+=temp
        D[0][c]='H'
    for r in range(numRows):
        for c in range(numCols):
            if seq1[r-1]==seq2[c-1]:
                B[r][c]=match
            else:
                B[r][c]=miss
def initMatrixA(A,B,D,seq1,seq2,gap,match,miss):
    r,c=1,1
    first,second,third=0,0,0
    maxScore=0
    numRows=len(seq1)+1
    numCols=len(seq2)+1
    for r in range(numRows):
        for c in range(numCols):
            first=A[r-1][c-1]+B[r][c]
            second=A[r-1][c]+gap
            third=A[r][c-1]+gap
            if max(first,second,third)==first:
                maxScore=first
                D[r][c]='D'
            elif max(first,second,third)==second:
                maxScore=second
                D[r][c]='V'
            elif max(first,second,third)==third:
                maxScore=third
                D[r][c]='H'

    outputSeq(D,seq1,seq2)
def outputSeq(D,seq1,seq2):
    r=len(seq1)
    c=len(seq2)
    i=r
    aligned1=[0 for x in range (len(seq1))]
    aligned2=[0 for x in range (len(seq2))]
    print(D)
    while D[r+1][c+1]!='0':
        if D[r+1][c+1]=='D':
            print(r)
            aligned1[i]+=seq1[r]
            aligned2[i]+=seq2[c]
            r=r-1
            c=c-1
            i=i-1
        elif D[r+1][c+1]=='V':
            print(r)
            aligned1[i]+=seq[r]
            aligned2[i]+='-'
            r=r-1
            i=i-1
        elif D[r+1][c+1]=='H':
            print(r)
            aligned1[i]='-'
            aligned2[i]=seq2[c]
            c=c-1
            i=i-1
        else: 
            r=r-1
            c=c-1
    output=open('output.a2m','w')
    output.write(">Seq1"+seq1+"\n>Seq2"+seq2)
    output.close()

if __name__ == '__main__':
    #fasta=sys.argv[1]
    fasta=open('hw_input.fa','r')
    fasta.readline().strip()
    seq=fasta.read()
    seq1=""
    seq2=""
    s=""
    j=""
    i=0
    k=1
    gap=-2

    match,miss=1,-1
    with open('hw_input.fa','r') as fasta:
        for line in fasta:
            if ">Seq 2" in line or i==1:
                j=line
                seq2+=j
                i=1


            elif i!=1:
                s=line
                seq1+=s



    seq1=seq1.split('\n',1)[-1]
    print (">Seq1\n"+seq1)
    seq2=seq2.split('\n',1)[-1]
    print (">Seq2\n"+seq2)
    A=[[0 for x in range(len(seq1)+10)] for x in range (len(seq2)+10)]
    B=[[0 for x in range(len(seq1)+10)] for x in range (len(seq2)+10)]
    D=[[0 for x in range(len(seq1)+10)] for x in range (len(seq2)+10)]
    initMatrix(B, D, seq1, seq2, gap, match, miss)
    initMatrixA(A,B,D,seq2,seq2,gap,match,miss)
    fasta.close()
    pass

ps我正在嘗試實現Needleman-Wunchst全局對齊算法。

r-=r
c-=c
i-=i

我不知道您打算在這里做什么,但這是不對的。 這些分配等效於:

r = r - r
c = c - c
i = i - i

從自身減去變量將始終為0。 您可能還寫了:

r = 0
c = 0
i = 0

也許您打算從每個中減去1。 那是:

r -= 1
c -= 1
i -= 1

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM