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,iceločíselný vypíše číslo v desítkové soustavě se znaménkem uceločíselný vypíše číslo v desítkové soustavě bez znaménka f,Fdoublevypíše číslo ve formátu s pohyblivou řádovou tečkou; malé a velké fse liší pouze ve způsobu výpisu nekonečna a chybného čísla (profse vypisujeinf,infinityanan; proFINF,INFINITYaNAN)e,Edoublevypíše hodnotu v semilogaritmickém tvaru ([ -]d.ddde[+/-]ddd); podle použitého písmena budeEve 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_formatdostupnou v systémech Microsoftug,Gdoublevypíše hodnotu jako kratší z řetězců získaných formáty f,Fneboe,E; na rozdíl od celočíselných formátů se nevypisují nevýznamné nulyx,Xceločíselný vypíše číslo v šestnáctkové soustavě bez znaménka, číslice 10 až 15 se pro typ xvypisují malými písmenya,b,c,d,e,f, pro typXvelkými písmenyA,B,C,D,E,Foceločíselný vypíše číslo v osmičkové soustavě bez znaménka schar *vypíše řetězec ccharvypíše znak pvoid *vypíše adresu a,Adoublevypíše obsah bytů v šestnáctkovém zápise začínajícím 0xnebo0X[1][2] (v C++11 iostreams funguje stejněhexfloat).nukazatel na intNic 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 hhPro celočíselný formát je použit parametr typu char.hPro celočíselný formát je použit parametr typu short.lPro celočíselný formát je použit parametr typu long.Pro formát s pohyblivou řádovou čárkou nemá žádný efekt.[4]
llPro celočíselný formát je použit parametr typu long long.LPro formát s pohyblivou řádovou čárkou je použit parametr typu long double.zPro celočíselný formát je použit parametr typu size_t.jPro celočíselný formát je použit parametr typu intmax_t.tPro 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
ovypisovat před nenulové číslo0
pro typxvypisovat před číslo0x
pro typXvypisovat před číslo0X
pro typye,E,faFvždy psát desetinnou tečku
pro typygaGvž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"
(
%apř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