fprintf

(PHP 5, PHP 7)

fprintfWrite a formatted string to a stream

Descrierea

fprintf ( resource $stream , string $format , mixed ...$values ) : int

Write a string produced according to format to the stream resource specified by stream.

Parametri

stream

O resursă de tip indicator în sistemul de fișiere care este în mod tipic creată utilizând fopen().

format

Șirul de formatare este compus din zero sau mai multe directive: caractere obișnuite (în afară de %), care sunt copiate direct în rezultat și specificatori de conversie, fiecare având parametrul său.

Un specificator de conversie e compus după următorul prototip: %[argnum$][flags][width][.precision]specifier.

Argnum

Un întreg urmat de senmul dolar $, pentru a specifica ce argument de număr trebuie tratat în conversie.

Flags
Flag Descriere
- Alinierea spre stânga în limitele lungimii câmpului; Implicit se efectuează alinierea spre dreapta
+ Prefixează numerele pozitive cu semnul plus +; implicit doar numerele negative sunt prefixate cu semnul minus.
(spațiu) Completează rezultatul cu spații. Acesta este comportamentul implicit.
0 Completează numerele cu zerouri în stânga. Cu specificatorii s se poate de completat cu zerouri și în dreapta.
'(char) Completează rezultatul cu caracterul (char).

Width

Un număr întreg ce indică câte caractere (minimum) trebuie să aibă rezultatul conversiei.

Precision

Un punct ., urmat de un număr întreg, însemnătatea căruia depinde de specificator:

  • Pentru specificatorii e, E, f și F: acesta este numărul de cifre ce vor fi tipărite după punctul zecimal (implicit acesta este 6).
  • Pentru specificatorii g și G: acesta este numărul maxim de cifre semnificative ce va fi tipărit.
  • Pentru specificatorul s: acesta funcționează ca punct de oprire, stabilind limita maximă a numărului de caractere din șir.

Notă: Dacă punctul este specificat fără o valoare explicită pentru precizie, se presupune că aceasta este 0.

Notă: Încercarea de a folosi un specificator de poziție mai mare decât PHP_INT_MAX va genera avertizări.

Specifiers
Specifier Descriere
% Specifică caracterul procent. Nu este necesar vre-un argument.
b Argumentul este tratat ca un întreg și prezentat ca număr binar.
c Argumentul este tratat ca un întreg și prezentat ca caracter cu acest cod ASCII.
d Argumentul este tratat ca un întreg și prezentat ca număr zecimal (cu semn).
e Argumentul este tratat ca număr în notație exponențială (de ex. 1.2e+2). Specificatorul de precizie semnifică numărul de cifre după virgulă începând cu PHP 5.2.1. În versiuni anterioare el specifica numărul de cifre semnificative (cu una mai puțin).
E La fel ca și specificatorul e, dar folosește caracterul majuscul (de ex. 1.2E+2).
f Argumentul este tratat ca număr cu virgulă și prezentat ca atare (în dependență de setările de localizare).
F Argumentul este tratat ca număr cu virgulă și prezentat ca atare (fără a se ține cont de setările de localizare). Disponibil începând cu PHP 5.0.3.
g

Format general.

Fie că P este egal cu precizia, dacă nu este zero, 6 dacă precizia este omisă, sau 1 dacă precizia este zero. Atunci dacă o conversie cu stilul E ar avea un exponent X:

Dacă P > X ≥ −4, atunci conversia este de stilul f și precizia P − (X + 1). În caz contrar, conversia este de stilul e și precizia P − 1.

G La fel ca și specificatorul g, dar utilizează E și f.
o Argumentul este tratat ca întreg și prezentat ca număr octal.
s Argumentul este tratat și prezentat ca șir de caractere.
u Argumentul este tratat ca întreg și prezentat ca număr zecimal fără semn.
x Argumentul este tratat ca întreg și prezentat ca număr hexazecimal (cu caractere minuscule).
X Argumentul este tratat ca întreg și prezentat ca număr hexazecimal (cu caractere majuscule).

Avertizare

Specificatorul de tip c ignoră completarea cu spații și lungimea

Avertizare

Încercarea de a folosi o combinație din specificatori de șiruri de caractere și lungime cu seturi de caractere ce necesită mai mult de un octet per caracter poate da rezultate imprevizibile

Variabilele vor fi aduse la un tip potrivit pentru specificatorul:

Manipularea tipurilor
Tipul Specificatorii
string s
integer d, u, c, o, x, X, b
double g, G, e, E, f, F

values

Valorile întoarse

Returns the length of the string written.

Exemple

Example #1 fprintf(): zero-padded integers

<?php
if (!($fp fopen('date.txt''w'))) {
    return;
}

fprintf($fp"%04d-%02d-%02d"$year$month$day);
// will write the formatted ISO date to date.txt
?>

Example #2 fprintf(): formatting currency

<?php
if (!($fp fopen('currency.txt''w'))) {
    return;
}

$money1 68.75;
$money2 54.35;
$money $money1 $money2;
// echo $money will output "123.1";
$len fprintf($fp'%01.2f'$money);
// will write "123.10" to currency.txt

echo "wrote $len bytes to currency.txt";
// use the return value of fprintf to determine how many bytes we wrote
?>

A se vedea și

add a note add a note

User Contributed Notes 1 note

up
2
Julien MOREAU
3 years ago
If you use the command line interface (CLI SAPI), you may be interested by the 3 standard input/output streams (STDIN, STDOUT & STDERR) described at: https://www.php.net/manual/en/features.commandline.io-streams.php
To Top