如何每行打印一个元组的元素
问题描述
以下是我的 DNA 字符串相邻问题的代码:
Below is my code for a DNA string neighboring question:
chars = "ACGT"
def neighbors(pattern, d):
assert(d <= len(pattern))
if d == 0:
return [pattern]
r2 = neighbors(pattern[1:], d-1)
r = [c + r3 for r3 in r2 for c in chars if c != pattern[0]]
if (d < len(pattern)):
r2 = neighbors(pattern[1:], d)
r += [pattern[0] + r3 for r3 in r2]
return r
def neighbors2(pattern, d):
return ([neighbors(pattern, d2) for d2 in range(d + 1)], [])
print (neighbors2("ACG", 1))
输出如下:
([['ACG'], ['CCG', 'GCG', 'TCG', 'AAG', 'AGG', 'ATG', 'ACA', 'ACC', 'ACT']], [])
如何添加一些代码并将输出更改为这种模式:
How can I add some codes and change the output looking like this kind of pattern:
CCG
TCG
GCG
AAG
ATG
AGG
ACA
ACC
ACT
ACG
解决方案
你可以使用compiler.ast模块中的flatten函数
You can use flatten function from compiler.ast module
from compiler.ast import flatten
print flatten(neighbors2("ACG", 1))
会产生
['ACG', 'CCG', 'GCG', 'TCG', 'AAG', 'AGG', 'ATG', 'ACA', 'ACC', 'ACT']
或
print("
".join(flatten(neighbors2("ACG", 1))))
有这样的输出:
ACG
CCG
GCG
TCG
AAG
AGG
ATG
ACA
ACC
ACT
相关文章