如何让内循环考虑外循环的每次迭代?
How do I make the inner loop consider each iteration of the outer loop?
三字母组,由'A', 'U', 'G' or 'C'
组成,定义为密码子。每个密码子对应于 20 个字母中的一个。这些字母(氨基酸)的集合被定义为蛋白质。文件 "codons.txt" 包含密码子和相应的字母。
接下来的问题是:内部 for 循环只工作一次——它只比较 txt 文件中的行和第一个密码子。然后,据我了解,该方法跳过了内部循环。
代码:
path = r'C:\Users\...\codons.txt'
f = open(path, 'r')
def prot(DNA):
protein = ''
a = True
for i in range (0, len(DNA)-2,3):
codon = DNA[i:i+3:1]
print(codon)
for line in f:
if line[0:3:1] == codon:
protein += line[4:5:1]
print(protein)
return protein
prot('AGUCAGGAUAGUCUUA')
输出:
AGU
S
CAG
GAU
AGU
CUU
接下来的问题是:如何让内环对每个密码子起作用?
遍历文件 (for line in f:
) 时,它会在到达文件末尾时停止。
您可以:
- 使用
f.seek(0)
将文件 reader 位置重置为文件开头
或更改循环的顺序,以便您只遍历文件一次。
def prot(DNA):
protein = ''
with open(path, 'r') as f:
for line in f:
for i in range (0, len(DNA)-2,3):
codon = DNA[i:i+3:1]
print(codon)
if line[0:3:1] == codon:
protein += line[4:5:1]
print(protein)
return protein
三字母组,由'A', 'U', 'G' or 'C'
组成,定义为密码子。每个密码子对应于 20 个字母中的一个。这些字母(氨基酸)的集合被定义为蛋白质。文件 "codons.txt" 包含密码子和相应的字母。
接下来的问题是:内部 for 循环只工作一次——它只比较 txt 文件中的行和第一个密码子。然后,据我了解,该方法跳过了内部循环。
代码:
path = r'C:\Users\...\codons.txt'
f = open(path, 'r')
def prot(DNA):
protein = ''
a = True
for i in range (0, len(DNA)-2,3):
codon = DNA[i:i+3:1]
print(codon)
for line in f:
if line[0:3:1] == codon:
protein += line[4:5:1]
print(protein)
return protein
prot('AGUCAGGAUAGUCUUA')
输出:
AGU
S
CAG
GAU
AGU
CUU
接下来的问题是:如何让内环对每个密码子起作用?
遍历文件 (for line in f:
) 时,它会在到达文件末尾时停止。
您可以:
- 使用
f.seek(0)
将文件 reader 位置重置为文件开头
或更改循环的顺序,以便您只遍历文件一次。
def prot(DNA): protein = '' with open(path, 'r') as f: for line in f: for i in range (0, len(DNA)-2,3): codon = DNA[i:i+3:1] print(codon) if line[0:3:1] == codon: protein += line[4:5:1] print(protein) return protein