❮ PHP 文字列リファレンス
例
パーセント (%) 記号を、引数として渡される変数に置き換えます。
<?php
$number = 9;
$str = "Beijing";
$txt = sprintf("There are %u million bicycles in %s.",$number,$str);
echo $txt;
?>
定義と使用法
sprintf() 関数は、書式設定された文字列を変数に書き込みます。
arg1、arg2、++ パラメータは、メイン文字列のパーセント (%) 記号に挿入されます。この機能は「段階的に」機能します。最初の % 記号で arg1 が挿入され、2 番目の % 記号で arg2 が挿入されます。
ノート:引数よりも多くの % 記号がある場合は、プレースホルダーを使用する必要があります。 % 記号の後にプレースホルダが挿入され、引数番号と "\$" で構成されます。例 2 を参照してください。
ヒント:関連機能:printf()、vprintf()、vsprintf()、fprintf()とvfprintf()
構文
<div>sprintf(<em>format,arg1,arg2,arg++</em>)</div>
パラメータ値
パラメータ |
説明 |
フォーマット |
必要。文字列と、文字列内の変数をフォーマットする方法を指定します。 可能なフォーマット値:
- %% - パーセント記号を返します
- %b - 2 進数
- %c - ASCII 値による文字
- %d - 符号付き 10 進数 (負、ゼロ、または正)
- %e - 小文字を使用した科学表記 (例: 1.2e+2)
- %E - 大文字を使用した科学表記 (例: 1.2E+2)
- %u - 符号なし 10 進数 (ゼロ以上)
- %f - 浮動小数点数 (ローカル設定対応)
- %F - 浮動小数点数 (ローカル設定を認識しない)
- %g - %e と %f の短い方
- %G - %E と %f の短い方
- %o - 8 進数
- %s - 文字列
- %x - 16 進数 (小文字)
- %X - 16 進数 (大文字)
追加のフォーマット値。これらは % と文字の間に置かれます (例 %.2f):
- + (数値の前に + と - の両方を強制します。デフォルトでは、負の数値のみがマークされます)
- ' (パディングとして使用するものを指定します。デフォルトはスペースです。幅指定子と一緒に使用する必要があります。例: %'x20s (これはパディングとして「x」を使用します)
- - (変数値を左寄せ)
- [0-9] (変数値に保持される最小幅を指定します)
- .[0-9] (10 進数の桁数または文字列の最大長を指定します)
ノート:複数の追加のフォーマット値を使用する場合は、上記と同じ順序にする必要があります。
|
arg1 |
必要。フォーマット文字列の最初の % 記号に挿入される引数 |
arg2 |
オプション。フォーマット文字列の 2 番目の % 記号に挿入される引数 |
引数++ |
オプション。 3 番目、4 番目などに挿入される引数。フォーマット文字列の %-記号 |
技術的な詳細
戻り値: |
フォーマットされた文字列を返します |
PHP バージョン: |
4+ |
その他の例
例
フォーマット値 %f の使用:
<?php
$number = 123;
$txt = sprintf("%f",$number);
echo $txt;
?>
例
プレースホルダーの使用:
<?php
$number = 123;
$txt = sprintf("With 2 decimals: %1\$.2f
<br>With no decimals: %1\$u",$number);
echo $txt;
?>
例
可能なすべてのフォーマット値のデモンストレーション:
<?php
$num1 = 123456789;
$num2 = -123456789;
$char = 50; // The ASCII Character 50 is 2
// Note: The format value "%%" returns a percent sign
echo sprintf("%%b = %b",$num1)."<br>"; // Binary number
echo sprintf("%%c = %c",$char)."<br>"; // The ASCII Character
echo sprintf("%%d = %d",$num1)."<br>"; // Signed decimal number
echo sprintf("%%d = %d",$num2)."<br>"; // Signed decimal number
echo sprintf("%%e = %e",$num1)."<br>"; // Scientific notation (lowercase)
echo sprintf("%%E = %E",$num1)."<br>"; // Scientific notation (uppercase)
echo sprintf("%%u = %u",$num1)."<br>"; // Unsigned decimal number (positive)
echo sprintf("%%u = %u",$num2)."<br>"; // Unsigned decimal number (negative)
echo sprintf("%%f = %f",$num1)."<br>"; // Floating-point number (local settings aware)
echo sprintf("%%F = %F",$num1)."<br>"; // Floating-point number (not local sett aware)
echo sprintf("%%g = %g",$num1)."<br>"; // Shorter of %e and %f
echo sprintf("%%G = %G",$num1)."<br>"; // Shorter of %E and %f
echo sprintf("%%o = %o",$num1)."<br>"; // Octal number
echo sprintf("%%s = %s",$num1)."<br>"; // String
echo sprintf("%%x = %x",$num1)."<br>"; // Hexadecimal number (lowercase)
echo sprintf("%%X = %X",$num1)."<br>"; // Hexadecimal number (uppercase)
echo sprintf("%%+d = %+d",$num1)."<br>"; // Sign specifier (positive)
echo sprintf("%%+d = %+d",$num2)."<br>"; // Sign specifier (negative)
?>
例
文字列指定子のデモ:
<?php
$str1 = "Hello";
$str2 = "Hello world!";
echo sprintf("[%s]",$str1)."<br>";
echo sprintf("[%8s]",$str1)."<br>";
echo sprintf("[%-8s]",$str1)."<br>";
echo sprintf("[%08s]",$str1)."<br>";
echo sprintf("[%'*8s]",$str1)."<br>";
echo sprintf("[%8.8s]",$str2)."<br>";
?>
❮ PHP 文字列リファレンス