13 ответов:
строки:
>>> n = '4' >>> print n.zfill(3) 004и номера:
>>> n = 4 >>> print '%03d' % n 004 >>> print format(n, '03') # python >= 2.6 004 >>> print '{0:03d}'.format(n) # python >= 2.6 004 >>> print '{foo:03d}'.format(foo=n) # python >= 2.6 004 >>> print('{:03d}'.format(n)) # python >= 2.7 + python3 004 >>> print('{0:03d}'.format(n)) # python 3 004 >>> print(f'{n:03}') # python >= 3.6 004
просто использовать rjust метод объекта String.
в этом примере будет сделана строка длиной 10 символов, заполнение по мере необходимости.
>>> t = 'test' >>> t.rjust(10, '0') >>> '000000test'
номера:
print "%05d" % numberЧитайте также: Python: форматирование строк.
EDIT: стоит отметить, что по состоянию на 3 декабря 2008 года, этот метод форматирования устарел в пользу
formatспособ строку:print("{0:05d}".format(number)) # or print(format(number, "05d"))посмотреть PEP 3101 для сведения.
>>> '99'.zfill(5) '00099' >>> '99'.rjust(5,'0') '00099'Если вы хотите, наоборот:
>>> '99'.ljust(5,'0') '99000'
работает как в Python 2, так и в Python 3:
>>> "{:0>2}".format("1") # Works for both numbers and strings. '01' >>> "{:02}".format(1) # Only works for numbers. '01'
str(n).zfill(width)будет работать сstrings,ints,floats... и это Python 2.x и 3.x совместимость:>>> n = 3 >>> str(n).zfill(5) '00003' >>> n = '3' >>> str(n).zfill(5) '00003' >>> n = '3.0' >>> str(n).zfill(5) '003.0'
для тех, кто пришел сюда, чтобы понять, а не просто быстрый ответ. Я делаю это специально для временных строк:
hour = 4 minute = 3 "{:0>2}:{:0>2}".format(hour,minute) # prints 04:03 "{:0>3}:{:0>5}".format(hour,minute) # prints '004:00003' "{:0<3}:{:0<5}".format(hour,minute) # prints '400:30000' "{:$<3}:{:#<5}".format(hour,minute) # prints '4$$:3####'символы " 0 "что заменить символами заполнения" 2", по умолчанию это пустое пространство
" > "символы allign все 2" 0 " символ слева от строки
":" символы format_spec
width = 10 x = 5 print "%0*d" % (width, x) > 0000000005смотрите документацию по печати для всех интересных деталей!
обновление для Python 3.x (7,5 лет спустя)
эта последняя строка теперь должна быть:
print("%0*d" % (width, x))то есть
print()теперь функция, а не оператор. Обратите внимание, что я все еще предпочитаю старую школуprintf()стиль, потому что, IMNSHO, он читается лучше, и потому, что я использую эту нотацию с января 1980 года. Что-то... пожилая собака. . что-то, что-то ... новый трюки.
каков самый питонический способ заполнить числовую строку нулями слева, т. е. чтобы числовая строка имела определенную длину?
str.zfillспециально предназначен для этого:>>> '1'.zfill(4) '0001'обратите внимание, что он специально предназначен для обработки числовых строк по запросу и перемещает
+или-к началу строки:>>> '+1'.zfill(4) '+001' >>> '-1'.zfill(4) '-001'вот помощь на
str.zfill:>>> help(str.zfill) Help on method_descriptor: zfill(...) S.zfill(width) -> str Pad a numeric string S with zeros on the left, to fill a field of the specified width. The string S is never truncated.производительность
это также самый эффективный из альтернативных методов:
>>> min(timeit.repeat(lambda: '1'.zfill(4))) 0.18824880896136165 >>> min(timeit.repeat(lambda: '1'.rjust(4, '0'))) 0.2104538488201797 >>> min(timeit.repeat(lambda: f'{1:04}')) 0.32585487607866526 >>> min(timeit.repeat(lambda: '{:04}'.format(1))) 0.34988890308886766чтобы лучше всего сравнить яблоки с яблоками для
%метод (обратите внимание, что это на самом деле медленнее), который в противном случае будет предварительно вычислить:>>> min(timeit.repeat(lambda: '1'.zfill(0 or 4))) 0.19728074967861176 >>> min(timeit.repeat(lambda: '%04d' % (0 or 1))) 0.2347015216946602реализация
немного покопавшись, я нашел реализацию
zfillметодObjects/stringlib/transmogrify.h:static PyObject * stringlib_zfill(PyObject *self, PyObject *args) { Py_ssize_t fill; PyObject *s; char *p; Py_ssize_t width; if (!PyArg_ParseTuple(args, "n:zfill", &width)) return NULL; if (STRINGLIB_LEN(self) >= width) { return return_self(self); } fill = width - STRINGLIB_LEN(self); s = pad(self, fill, 0, '0'); if (s == NULL) return NULL; p = STRINGLIB_STR(s); if (p[fill] == '+' || p[fill] == '-') { /* move sign to beginning of string */ p[0] = p[fill]; p[fill] = '0'; } return s; }давайте пройдемся это C-код.
он сначала анализирует аргумент позиционно, что означает, что он не позволяет аргументы ключевых слов:
>>> '1'.zfill(width=4) Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: zfill() takes no keyword argumentsзатем он проверяет, имеет ли он ту же длину или больше, и в этом случае он возвращает строку.
>>> '1'.zfill(0) '1'
zfillзвонкиpad(этоpadфункция также вызываетсяljust,rjustиcenterкак хорошо). Это в основном копирует содержимое в новую строку и заполняет поля.static inline PyObject * pad(PyObject *self, Py_ssize_t left, Py_ssize_t right, char fill) { PyObject *u; if (left < 0) left = 0; if (right < 0) right = 0; if (left == 0 && right == 0) { return return_self(self); } u = STRINGLIB_NEW(NULL, left + STRINGLIB_LEN(self) + right); if (u) { if (left) memset(STRINGLIB_STR(u), fill, left); memcpy(STRINGLIB_STR(u) + left, STRINGLIB_STR(self), STRINGLIB_LEN(self)); if (right) memset(STRINGLIB_STR(u) + left + STRINGLIB_LEN(self), fill, right); } return u; }после звоню
pad,zfillперемещает любой первоначально предшествующий+или-к началу строки.обратите внимание, что для того, чтобы исходная строка действительно была числовой, не требуется:
>>> '+foo'.zfill(10) '+000000foo' >>> '-foo'.zfill(10) '-000000foo'
для zip-коды сохраняются в виде целых чисел:
>>> a = 6340 >>> b = 90210 >>> print '%05d' % a 06340 >>> print '%05d' % b 90210
быстрое сравнение времени:
setup = ''' from random import randint def test_1(): num = randint(0,1000000) return str(num).zfill(7) def test_2(): num = randint(0,1000000) return format(num, '07') def test_3(): num = randint(0,1000000) return '{0:07d}'.format(num) def test_4(): num = randint(0,1000000) return format(num, '07d') def test_5(): num = randint(0,1000000) return '{:07d}'.format(num) def test_6(): num = randint(0,1000000) return '{x:07d}'.format(x=num) def test_7(): num = randint(0,1000000) return str(num).rjust(7, '0') ''' import timeit print timeit.Timer("test_1()", setup=setup).repeat(3, 900000) print timeit.Timer("test_2()", setup=setup).repeat(3, 900000) print timeit.Timer("test_3()", setup=setup).repeat(3, 900000) print timeit.Timer("test_4()", setup=setup).repeat(3, 900000) print timeit.Timer("test_5()", setup=setup).repeat(3, 900000) print timeit.Timer("test_6()", setup=setup).repeat(3, 900000) print timeit.Timer("test_7()", setup=setup).repeat(3, 900000) > [2.281613943830961, 2.2719342631547077, 2.261691106209631] > [2.311480238815406, 2.318420542148333, 2.3552384305184493] > [2.3824197456864304, 2.3457239951596485, 2.3353268829498646] > [2.312442972404032, 2.318053102249902, 2.3054072168069872] > [2.3482314132374853, 2.3403386400002475, 2.330108825844775] > [2.424549090688892, 2.4346475296851438, 2.429691196530058] > [2.3259756401716487, 2.333549212826732, 2.32049893822186]Я сделал различные тесты различных повторений. Различия не огромны, но во всех тестах,
zfillрешение было быстрым.
вы также можете повторить "0", добавить его к
str(n)и получить самый правый срез ширины. Быстрое и грязное выражение лица.def pad_left(n, width, pad="0"): return ((pad * width) + str(n))[-width:]
Comments