Вопрос

Я использую эту простую функцию:

def print_players(players):
    tot = 1
    for p in players:
        print '%2d: %15s \t (%d|%d) \t was: %s' % (tot, p['nick'], p['x'], p['y'], p['oldnick'])
        tot += 1

и я предполагаю, что ники не длиннее 15 символов.
Я хотел бы сохранить каждый столбец выровнен, есть ли какой-то синтаксический сахар, позволяющий мне делать то же самое, но держать столбец псевдонимов выровненным по левому краю вместо выровненного по правому краю, не разбивая столбец справа?

Эквивалентный, более уродливый код:

def print_players(players):
    tot = 1
    for p in players:
        print '%2d: %s \t (%d|%d) \t was: %s' % (tot, p['nick']+' '*(15-len(p['nick'])), p['x'], p['y'], p['oldnick'])
        tot += 1

Спасибо всем, вот окончательная версия:

def print_players(players):
    for tot, p in enumerate(players, start=1):
        print '%2d:'%tot, '%(nick)-12s (%(x)d|%(y)d) \t was %(oldnick)s'%p
Это было полезно?

Решение

Видя, что p кажется диктатом, как насчет:

print '%2d' % tot + ': %(nick)-15s \t (%(x)d|%(y)d) \t was: %(oldnick)15s' % p

Другие советы

Для выравнивания по левому краю вместо выравнивания по правому краю используйте % - 15 с вместо % 15 с .

Немного не по теме, но вы можете избежать явного добавления tot , используя перечислять :

for tot, p in enumerate(players, start=1):
    print '...'

Или, если вы используете python 2.6, вы можете использовать формат метод строки:

Это определяет словарь значений и использует их для dipslay:

>>> values = {'total':93, 'name':'john', 'x':33, 'y':993, 'oldname':'rodger'}
>>> '{total:2}: {name:15} \t ({x}|{y}\t was: {oldname}'.format(**values)
'93: john            \t (33|993\t was: rodger'
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top