printf
printf
je funkce v programovacím jazyce C, která provádí formátovaný výpis dat v textové podobě.
Funkce má proměnný počet parametrů a na standardní výstup vypíše textový řetězec zadaný prvním parametrem, v němž jsou formátovací direktivy nahrazeny hodnotami dalších parametrů. Použitý způsob formátování byl převzat do mnoha dalších programovacích jazyků a některé unixové shelly obsahují stejně pojmenovaný příkaz pro formátovaný výpis dat.
Příklad použití
printf("Dnes je %s %d. %s %d; teplota je %+.1f stupňů Celsia.\n", dny_v_tydnu[dt], den, mesice[mesic], rok, teplota);
může vypsat
Dnes je středa 11. července 2018; teplota je +20.5 stupňů Celsia.
s odřádkováním na konci.
Příbuzné funkce
Ve standardní knihovně jazyka C je několik podobných funkcí deklarovaných v hlavičkovém souboru stdio.h
:
printf
– pro formátovaný výpis na standardní výstupfprintf
– pro formátovaný výstup do libovolného souboru, resp. datového proudu otevřeného pro výstupsprintf
– ukládá výstup do řetězcesnprintf
– ukládá výstup do řetězce omezené délky
Dále existují varianty pro výstup řetězců v kódování UTF-32 složených ze znaků wide char
(typu wchar_t
); tyto funkce mají ve jméně wprintf
místo printf
, a funkce deklarované v hlavičkovém souboru stdarg.h
, jimž se volitelné parametry předávají pomocí struktury va_list
, jejichž jména začínají písmenem v
– například funkce vswprintf
ukládá výstup zadaný strukturou va_list
a formátovacím řetězcem typu wchar_t *
a do řetězce téhož typu omezené délky (varianty pro wide char
pracují vždy s řetězci omezené délky a jejich jména místo sn
obsahují pouze sw
).
Všechny uvedené funkce vracejí počet zapsaných znaků nebo zápornou hodnotu v případě chyby.
Podobnou filozofii mají funkce řady scanf
, které provádějí naopak vstupní konverzi.
Formátovací řetězec
Jedním z parametrů všech uvedených funkcí je formátovací řetězec, který může obsahovat sekvence pro výpis řídicích znaků začínající znakem zpětné lomítko (\
) a formátovací direktivy začínající znakem procento (%
).
Syntaxe
Syntaxe formátovacích direktiv je následující:
%[číslo parametru][příznaky][šířka][.přesnost][velikost]typ
Typ
Jako typ lze použít některý z níže uvedených znaků:
Typ Parametr Význam %
(žádný) vypíše znak %
d
,i
celočíselný vypíše číslo v desítkové soustavě se znaménkem u
celočíselný vypíše číslo v desítkové soustavě bez znaménka f
,F
double
vypíše číslo ve formátu s pohyblivou řádovou tečkou; malé a velké f
se liší pouze ve způsobu výpisu nekonečna a chybného čísla (prof
se vypisujeinf
,infinity
anan
; proF
INF
,INFINITY
aNAN
)e
,E
double
vypíše hodnotu v semilogaritmickém tvaru ([ -
]d.ddde
[+
/-
]ddd); podle použitého písmena budeE
ve výpisu malé nebo velké; exponent má vždy nejméně dvě číslice; pro nulu je exponent00
; ve Windows má exponent implicitně tři číslice, tj.1.5e002
, lze změnit funkcí_set_output_format
dostupnou v systémech Microsoftug
,G
double
vypíše hodnotu jako kratší z řetězců získaných formáty f
,F
neboe
,E
; na rozdíl od celočíselných formátů se nevypisují nevýznamné nulyx
,X
celočíselný vypíše číslo v šestnáctkové soustavě bez znaménka, číslice 10 až 15 se pro typ x
vypisují malými písmenya
,b
,c
,d
,e
,f
, pro typX
velkými písmenyA
,B
,C
,D
,E
,F
o
celočíselný vypíše číslo v osmičkové soustavě bez znaménka s
char *
vypíše řetězec c
char
vypíše znak p
void *
vypíše adresu a
,A
double
vypíše obsah bytů v šestnáctkovém zápise začínajícím 0x
nebo0X
[1][2] (v C++11 iostreams funguje stejněhexfloat
).n
ukazatel na int
Nic nevypisuje, ale do příslušného parametru uloží počet dosud vypsaných znaků (v rámci tohoto vyvolání printf
Java: indikuje platformně neutrální znak konce řádku[3]
Poznámka: tento parametr může být zneužit při útocích Uncontrolled format string
Velikost
Pole velikost udává přesný typ příslušného parametru:
Velikost Význam hh
Pro celočíselný formát je použit parametr typu char
.h
Pro celočíselný formát je použit parametr typu short
.l
Pro celočíselný formát je použit parametr typu long
.Pro formát s pohyblivou řádovou čárkou nemá žádný efekt.[4]
ll
Pro celočíselný formát je použit parametr typu long long
.L
Pro formát s pohyblivou řádovou čárkou je použit parametr typu long double
.z
Pro celočíselný formát je použit parametr typu size_t
.j
Pro celočíselný formát je použit parametr typu intmax_t
.t
Pro celočíselný formát je použit parametr typu ptrdiff_t
.
Např.: printf("%ld", (long int) 1234567)
Přesnost
U formátů s pohyblivou řádovou čárkou udává, na kolik desetinných míst má být výpis čísla zaokrouhlen; u řetězců udává maximální počet znaků, které mají být vypsány.
Pole může být vynecháno, může být zadáno číslem, nebo hvězdičkou; hvězdička znamená, že hodnota je zadána parametrem typu int
.
Např. printf("%.*s", 3, "abcdef")
vypíše abc
Šířka
Šířka udává minimální počet znaků, které mají být vypsány; pokud by byl výstup kratší bude doplněn mezerami (přesný způsob závisí na použitých příznacích). Pole šířka nikdy nezpůsobí zkrácení výpisu.
Zadání šířky může být vynecháno, může být použito číslo, nebo hvězdička; hvězdička znamená, že hodnotu udává další parametr typu int
Např. printf("%0*d", 5, 10)
vypíše 00010
.
Příznaky
Je možné použít žádný, jeden nebo více příznaků v libovolném pořadí:
Příznak Význam -
(minus)zarovnat vlevo, vpravo doplnit mezerami +
(plus)před číslem vždy vypsat znaménko (i plus)
(mezera)před záporným číslem vypsat -, před kladným mezeru #
(hash)použít alternativní formát výpisu: pro typ
o
vypisovat před nenulové číslo0
pro typx
vypisovat před číslo0x
pro typX
vypisovat před číslo0X
pro typye
,E
,f
aF
vždy psát desetinnou tečku
pro typyg
aG
vždy psát tečku, neusekávat koncové nuly0
(nula)Pokud je použito pro numerický typ a je zadána šířka, doplní číslo na zadanou šířku zleva nulami; zatímco printf("%2X",3)
vypíše3
, takprintf("%02X",3)
vypíše03
.
Číslo parametru
Číslo parametru je rozšíření POSIX, které není obsaženo v normě C99. Používá se například při lokalizaci softwaru, když je potřeba změnit pořadí slov zadaných jako parametry. Pokud je číslo parametru použito v jedné formátovací direktivě, musí být použito u všech v daném volání printf. Jeho tvar je:
Hodnota Význam n$
n je číslo parametru, který má být vypsán touto formátovací direktivou; opakováním téhož čísla je možné vypsat jeden parametr vícekrát i s použitím různých formátů
Např.printf("%2$d (%2$x hex); %1$d (%1$x hex)",16,17)
vypíše17 (11 hex); 16 (10 hex)
.
Odkazy
Reference
V tomto článku byl použit překlad textu z článku printf format string na anglické Wikipedii.
- ↑ "The GNU C Library Reference Manual", "12.12.3 Table of Output Conversions" [online]. Gnu.org [cit. 2014-03-17]. Dostupné online.
- ↑ "printf" (
%a
přidáno v C99) - ↑ Formatting Numeric Print Output [online]. Oracle Inc. [cit. 2018-03-19]. Dostupné online.
- ↑ ISO/IEC (1999). ISO/IEC 9899:1999(E): Programming Languages - C §7.19.6.1 para 7