master
mhiretskiy 16 years ago
parent 425cfbea95
commit 65ea39fcfa

@ -54,8 +54,10 @@ def prettyColumnStr(*cols):
cols = list(cols) cols = list(cols)
# перевести текст в юникод, заодно перевести числа в строку # перевести текст в юникод, заодно перевести числа в строку
noconvert = False noconvert = False
space = u' '
for i in xrange(0,len(cols),2): for i in xrange(0,len(cols),2):
if type(cols[i]) == types.UnicodeType: if type(cols[i]) == types.UnicodeType:
space = " "
noconvert = True noconvert = True
cols[i] = _toUNICODE(cols[i]) cols[i] = _toUNICODE(cols[i])
# флаг "есть еще текст для вывода" # флаг "есть еще текст для вывода"
@ -76,6 +78,14 @@ def prettyColumnStr(*cols):
partstr = cols[q][:cols[q+1]] partstr = cols[q][:cols[q+1]]
# искать перевод строки с полученной части # искать перевод строки с полученной части
brfind = wherenr.search(partstr) brfind = wherenr.search(partstr)
# если это не последняя колонка
if q + 2 < len(cols):
# добавить разделитель между колонками
cellspacing = space
else:
# разделитель не нужен
cellspacing = ""
# если перевод строки найден, то # если перевод строки найден, то
if brfind != None: if brfind != None:
# для текущего вывода в колонку # для текущего вывода в колонку
@ -83,13 +93,13 @@ def prettyColumnStr(*cols):
partstr = partstr[:brfind.start()] partstr = partstr[:brfind.start()]
# остальная часть идет в остаток (без перевода) # остальная часть идет в остаток (без перевода)
cols[q] = cols[q][brfind.start()+1:] cols[q] = cols[q][brfind.start()+1:]
# если используется перевод каретки # # если используется перевод каретки
if brfind.group() == '\r': # if brfind.group() == '\r':
# то выравниваем по ширине колонки # # то выравниваем по ширине колонки
partstr = justify(partstr, cols[q+1]) # partstr = partstr.ljust(cols[q+1], ' ')
else: # else:
# добавить отступы чтобы закончить колонку # # добавить отступы чтобы закончить колонку
partstr = partstr.ljust(cols[q+1], ' ') partstr = partstr.ljust(cols[q+1], ' ')
# если взята часть строки # если взята часть строки
elif len(partstr) == cols[q+1] and partstr != cols[q]: elif len(partstr) == cols[q+1] and partstr != cols[q]:
# если взята часть строки (разрыв в слове) # если взята часть строки (разрыв в слове)
@ -110,7 +120,8 @@ def prettyColumnStr(*cols):
# ислючить переносной пробел # ислючить переносной пробел
cols[q] = cols[q][cols[q+1]+1:] cols[q] = cols[q][cols[q+1]+1:]
# выровнить текст по ширине колонки # выровнить текст по ширине колонки
partstr = justify(partstr, cols[q+1]) partstr = partstr.ljust(cols[q+1], ' ')
#partstr = justify(partstr, cols[q+1])
# остатки строки # остатки строки
else: else:
# добавить отступы чтобы закончить колонку # добавить отступы чтобы закончить колонку
@ -119,9 +130,10 @@ def prettyColumnStr(*cols):
# добавить к возвращаемой строки полученную + пробел # добавить к возвращаемой строки полученную + пробел
if noconvert: if noconvert:
retstr+= partstr + u' ' retstr+= partstr + cellspacing
else: else:
retstr+= partstr.encode('utf8') + " " retstr+= partstr.encode('utf8') + cellspacing
# остальную часть строки оставить на следующую итерацию # остальную часть строки оставить на следующую итерацию
# если от строки что то осаталось # если от строки что то осаталось
if len(cols[q]) > 0: if len(cols[q]) > 0:
@ -226,8 +238,6 @@ def columnWrite(*cols):
print print
def justify(s,width): def justify(s,width):
# добавить отступы чтобы закончить колонку
return s.ljust(width, ' ')
'''Выровнить текст по ширине '''Выровнить текст по ширине
Параметры: Параметры:

Loading…
Cancel
Save