我有这个功能可以比较我从txt文件中提取的统计数据,因此它们是静态的。我试图想出一种方法来将每个种族/亚种的统计数据与名称排列在一起。这是来源:
def compare():
print('------ Compare Race Stats ------')
comp1 = query()
comp2 = query()
comp1 = stats(comp1[0],comp1[1])
comp2 = stats(comp2[0],comp2[1])
print('{} - {} | {} - {}'
.format(comp1[0][0],comp1[0][1],comp2[0][0],comp2[0][1]))
for i in range(len(comp1[1])):
print('{}{}{}{}'.format(' '*round(len(comp1[0][0])+len(comp1[0][1])/5),comp1[1][i],
' '*round(len(comp2[0][0])+2+len(comp2[0][1])/5),comp2[1][i]))
query()
询问您想要的种族/子种族,并为每种种族/子种族返回字符串。 stats()
获取种族/子名称,从txt文件中提取并返回统计信息以及名称。第二个空白空间计算中的+2
是我对第一个打印语句(print('{} - {} | {} - {}'
)的计算,这是一个猜测。输出看起来并不那么糟糕,我认为空间计算有点聪明(我是一个菜鸟),但我不禁想知道Stack Overflow会说些什么。是否有一些可接受的方法来排列各种产出。
这是一些输出,有10种不同的种族/子种:
Elezen - Duskwight | Hyur - Midlander
STR : 20 STR : 21
DEX : 20 DEX : 19
VIT : 19 VIT : 20
INT : 23 INT : 21
MND : 20 MND : 18
PIE : 18 PIE : 21
Mi'Qote - Seekers of the Sun | Mi'Qote - Keepers of the Moon
STR : 21 STR : 18
DEX : 22 DEX : 21
VIT : 20 VIT : 17
INT : 18 INT : 19
MND : 19 MND : 23
PIE : 20 PIE : 22
答案 0 :(得分:0)
经过一番研究后,我找到了rjust
和ljust
str
函数:
def compare():
print("------ Compare Race Stats ------")
comp1 = query()
comp2 = query()
comp1 = stats(comp1[0], comp1[1])
comp2 = stats(comp2[0], comp2[1])
print("{} - {} | {} - {}"
.format(comp1[0][0], comp1[0][1], comp2[0][0], comp2[0][1]))
for i in range(len(comp1[1])):
print("{} {} {}".format(comp1[1][i].rjust(len(comp1[0][0]+comp1[0][1])+3),
"|", comp2[1][i]))
这是输出:
Roegadyn - Hellsguard | Elezen - Duskwight
STR : 20 | STR : 20
DEX : 17 | DEX : 20
VIT : 21 | VIT : 19
INT : 20 | INT : 23
MND : 22 | MND : 20
PIE : 20 | PIE : 18
Mi'Qote - Keepers of the Moon | Roegadyn - Hellsguard
STR : 18 | STR : 20
DEX : 21 | DEX : 17
VIT : 17 | VIT : 21
INT : 19 | INT : 20
MND : 23 | MND : 22
PIE : 22 | PIE : 20
我很抱歉在发帖之前提出一个我应该回答的问题,至少我能做到这一点显然会给出答案。