php sprintf ведущие нули
sprintf — Возвращает отформатированную строку
Описание
Список параметров
Переменные будут преобразованы в соответвующий тип для спецификатора:
| Тип | Спецификатор |
|---|---|
| string | s |
| integer | d, u, c, o, x, X, b |
| double | g, G, e, E, f, F |
Попытка использовать комбинацию строк и спецификаторов ширины с кодировками, которые требуют более одного байта на символ, может привести к неожиданным результатам.
В строке формата поддерживается нумерация и изменение порядка параметров. Например:
Пример #1 Изменение порядка параметров
= 5 ;
$location = ‘дереве’ ;
Пример #2 Изменение порядка параметров
Пример #3 Изменение порядка параметров
Пример #4 Изменение порядка параметров
Пример #5 Указание дополняющего символа
Результат выполнения данного примера:
Пример #6 Использование описателя позиции и совместно с другими описателями
Результат выполнения данного примера:
The c type specifier ignores padding and width
Возвращаемые значения
Примеры
Пример #7 sprintf() : заполнение нулями
Результат выполнения данного примера:
Пример #8 printf() : описатели строк
= ‘monkey’ ;
$t = ‘many monkeys’ ;
Результат выполнения данного примера:
Пример #9 sprintf() : целые числа, дополненные нулями
Пример #10 sprintf() : форматирование денежных величин
Пример #11 sprintf() : научная нотация
Смотрите также
sprintf
(PHP 4, PHP 5, PHP 7, PHP 8)
sprintf — Возвращает отформатированную строку
Описание
Список параметров
Строка формата состоит из нуля или более директив: обычные символы (за исключением % ), которые просто выводятся без изменения и спецификаторы преобразования, каждый из которых требует передачи своего параметра.
Argnum
| Флаг | Описание |
|---|---|
| — | Выравнивание по левому краю в пределах заданной ширины поля; По умолчанию выравнивание происходит по правому краю. |
| + | Печатает плюс + у не отрицательных чисел; По умолчанию знак печатается только у отрицательных чисел. |
| (space) | Дополняет результат пробелами. Это поведение по умолчанию. |
| 0 | Дополняет числа нулями (только слева). Со спецификатором s также может дополнять нулями справа. |
| ‘ (char) | Дополняет результат символом (char). |
Ширина
Целое число, определяющее минимальное количество символов, которое будет напечатано.
Точность
Замечание: Если указана точка без последующего значения точности, то точность будет считаться за 0.
Замечание: Попытка использовать спецификатор позиции со значением больше, чем PHP_INT_MAX приведёт к выводу предупреждения.
Если P > X ≥ −4, преобразование будет в стиле «f» и точность будет P − (X + 1). В обратном случае, преобразование будет в стиле «e» и точность будет P − 1.
Спецификатор c игнорирует значения ширины и дополнения
Попытка использовать спецификаторы с указанием ширины для строки в многобайтовой кодировке может привести к неожиданным результатам.
Возвращаемые значения
Список изменений
| Версия | Описание |
|---|---|
| 8.0.0 | Функция больше не возвращает false в случае возникновения ошибки. |
Примеры
Пример #1 Argument swapping
Строка формата поддерживает нумерацию и перемешивание аргументов.
Результат выполнения данного примера:
Теперь представим, что строка форматирования задаётся в стороннем файле. Это обычная практика при необходимости поддержки нескольких языков. Представим, что строка была переписана таким образом:
Дополнительным приятным моментом является то, что мы можем использовать один параметр для нескольких подстановок.
При использовании нумерованных аргументов, спецификатор позиции n$ должен стоять сразу же за символом процента ( % ), до любого другого спецификатора, как показано ниже.
Пример #2 Использование символа заполнения
Результат выполнения данного примера:
Пример #3 Спецификатор позиции в комбинации с другими спецификаторами
Результат выполнения данного примера:
Пример #4 sprintf() : целое с лидирующими нулями
Пример #5 sprintf() : форматирование денежных единиц
Результат выполнения данного примера:
Пример #6 sprintf() : научная нотация
Результат выполнения данного примера:
Смотрите также
User Contributed Notes 36 notes
With printf() and sprintf() functions, escape character is not backslash ‘\’ but rather ‘%’.
1. A plus sign (‘+’) means put a ‘+’ before positive numbers while a minus sign (‘-‘) means left justify. The documentation incorrectly states that they are interchangeable. They produce unique results that can be combined:
2. Padding with a ‘0’ is different than padding with other characters. Zeros will only be added at the front of a number, after any sign. Other characters will be added before the sign, or after the number:
There are already some comments on using sprintf to force leading leading zeros but the examples only include integers. I needed leading zeros on floating point numbers and was surprised that it didn’t work as expected.
This threw me a little off. To get the desired result, one needs to add the precision (2) and the length of the decimal seperator «.» (1). So the correct pattern would be
Please see http://stackoverflow.com/a/28739819/413531 for a more detailed explanation.
Here is how to print a floating point number with 16 significant digits regardless of magnitude:
$format = ‘There are %1$d monkeys in the %s and %s ‘;
printf($format, 100, ‘Chennai’, ‘Bangalore’);
Expecting to output
«There are 100 monkeys in the Chennai and bangalore»
But, this will output
«There are 100 monkeys in the 100 and Chennai»
Because, the second and Third specifiers takes 1rst and 2nd arguments. Because it is not assigned with any arguments.
Using argument swapping in sprintf() with gettext: Let’s say you’ve written the following script:
#: file.php:9
#, ycp-format
msgid «The %2\\$s contains %1\\$d monkeys»
msgstr «»
Notice how an extra backslash has been added by xgettext.
Once you’ve translated the string, you must remove all backslashes from the ID string as well as the translation, so the po file will look like this:
#: file.php:9
#, ycp-format
msgid «The %2$s contains %1$d monkeys»
msgstr «Der er %1$d aber i %2$s»
If you use the default padding specifier (a space) and then print it to HTML, you will notice that HTML does not display the multiple spaces correctly. This is because any sequence of white-space is treated as a single space.
To overcome this, I wrote a simple function that replaces all the spaces in the string returned by sprintf() with the character entity reference » » to achieve non-breaking space in strings returned by sprintf()
The old «monkey» example which helped me a lot has sadly disappeared.
I’ll Re-post it in comment as a memory.
/*
%b = ‘10100111101010011010101101’
%c = ‘A’
%d = ‘43951789’
%e = ‘4.395179e+7’
%u = ‘43951789’
%u = ‘18446744073665599827’
%f = ‘43951789.000000’
%o = ‘247523255’
%s = ‘43951789’
%x = ’29ea6ad’
%X = ’29EA6AD’
%+d = ‘+43951789’
%+d = ‘-43951789’
*/
$s = ‘monkey’ ;
$t = ‘many monkeys’ ;
Note that when using the argument swapping, you MUST number every argument, otherwise sprintf gets confused. This only happens if you use number arguments first, then switch to a non-numbered, and then back to a numbered one.
I had a nightmare trying to find the two’s complement of a 32 bit number.
This worked magic for me. previously I was trying to use
Hope this helps someone fighting with two’s complement in PHP.
A more complete and working version of mb_sprintf and mb_vsprintf. It should work with any «ASCII preserving» encoding such as UTF-8 and all the ISO-8859 charsets. It handles sign, padding, alignment, width and precision. Argument swapping is not handled.
$newformat = «» ; // build a new format in UTF-8
$newargv = array(); // unhandled args in unchanged encoding
If you use argument numbering, then format specifications with the same number get the same argument; this can save repeating the argument in the function call.
Just wanted to add that to get the remaining text from the string, you need to add the following as a variable in your scanf
Here’s a clean, working version of functions to allow using named arguments instead of numeric ones. ex: instead of sprintf(‘%1$s’, ‘Joe’);, we can use sprintf(‘%name$s’, array(‘name’ => ‘Joe’));. I’ve provided 2 different versions: the first uses the php-like syntax (ex: %name$s), while the second uses the python syntax (ex: %(name)s).
Php sprintf ведущие нули
Описание string sprintf ( string format [, mixed args] )
Каждый описатель прреобразований состоит из знака процента ( % ), за которым следует один или более дополнительных элементов (в том порядке, в котором они здесь перечислены):
Начиная с PHP 4.0.6 в строке формата поддерживается нумерация и изменение порядка параметров. Например:
Пример 1. Изменение порядка параметров |
Пример 2. Изменение порядка параметров |
Пример 3. Изменение порядка параметров |