![]() ![]() |
ARCHIV |
||||||||||||||||||||||||||||||||||||||||||||
![]() ![]() ![]() ![]() ![]() ![]() |
|
Formát | Význam |
%c | znak, odpovídající dané ASCII hodnotě |
%s | řetězec |
%d | celé číslo v desítkové soustavě |
%u | celé nezáporné číslo v desítkové soustavě |
%o | celé nezáporné číslo v osmičkové soustavě |
%b | celé nezáporné číslo v dvojkové soustavě |
%x, %X | celé nezáporné číslo v šestnáctkové soustavě (a-f, A-F) |
%f | desetinné číslo |
%e, %E | desetinné číslo v semilogaritmickém tvaru |
%g | automaticky se nahradí za %f nebo %e |
%p | adresa v paměti (šestnáctkově) |
%n | má zvláštní význam - do proměnné přiřadí počet dosud vytisknutých znaků |
%% | znak procento |
Podívejme se na konkrétní příklady.
$f = 350 / 3;#v $f je hodnota 116.666666666667
printf("Znak s ASCII hodnotou 116: %c", $f);#t
printf("Řetězec: %s", $f); #116.666666666667
printf("Celé číslo: %d", $f); #116
printf("Celé číslo šestnáctkově: %x", $f); #74
printf("Desetinné číslo: %f", $f); #116.666667
printf("Semilogaritmický tvar: %e", $f); #1.166667e+02
printf("Adresa: %p", $f); #816cafc
printf ("Text o 17 znacích%n a další text.", $n);
print $n; #17
Toto byly příklady toho nejjednoduššího užití. Řídící sekvence začínající znakem % mají ve skutečnosti mnohem rozsáhlejší syntaxi. Zde je její kompletní zápis.
%[příznaky][minimální_délka][.počet_desetinných míst]typ
To, co jsme si doposud ukázali bylo určení typu. Právě typ musí obsahovat každý formátovací řetězec. Vše ostatní je nepovinné.
Příznaky určují způsob, jakým se bude hodnota zarovnávat. Pokud by zabírala hodnota méně znaků, než kolik je v šabloně, lze nastavit na jakou stranu hodnotu zarovnat a případně čím.
Příznak | Význam |
0 | zleva zarovná nulami |
mezera | zleva zarovná mezerami |
- | zprava zarovná mezerami |
+ | vnutí znaménko +, je-li číslo kladné |
# | nejedná-li se o číslo v desítkové soustavě, vypisuje před ním 0x, 0, respektive 0b |
Minimální délka specifikuje, kolik znaků bude minimálně číslo nebo řetězec zabírat. Pokud je hodnota kratší než minimální délka, doplní se například mezerami. Záleží na nastavení příznaku.
Počet desetinných míst (tedy počet číslic za desetinnou tečkou) určuje přesnost. Začíná vždy tečkou. U celých čísel a řetězců určuje maximální délku.
printf("Dvojkové číslo s prefixem. %#b", 9444);#0b10010011100100
printf("Vnucené znaménko. %+d", 99); #+99
printf(">% 5d<", 10); #> 10<
printf(">%-5d<", 10); #>10 <
printf(">%05d<", 10); #>00010<
printf("Zaokrouhlování: %.3f", 9995.32154532); #9995.322
printf("%+010.3f", 9995.32154532); #+09995.322
printf("%.5s", "Nevejde se..."); #Nevej
printf("desítkově:
%d\nšestnáctkově:
%x\nosmičkově: %o\ndvojkově: %b\n", 250, 250, 250, 250);
#desítkově: 250
#šestnáctkově: fa
#osmičkově: 372
#dvojkově: 11111010
printf("pi = %.10f\n", 4 * atan2(1, 1)); #3.1415926536
$plan = 11200;
$vyrobeno = 10355;
printf("Plán je splněn z %3.1f%%\n", $vyrobeno / $plan * 100);
#Plán je splněn z 92.5%
Přesnost čísla pomocí proměnných lze zadávat i pomocí znaku *. Tyto zápisy mají stejný význam.
printf ">%${pocet}d<", 5;
printf ">%*d<", $pocet, 5;
Pomocí sekvence \$ lze určovat, který argument ze seznamu se použije.
printf "%2\$d", 11, 22, 33;
Do formátovacího řetězce můžeme připsat znak v a řetězec se rozloží na celá čísla oddělená implicitně tečkou.
printf "%vd/font>\n", 123;
printf umí ještě další věci, ale již jen odkazuji na manuálovou stránku perlfunc(1).
Abychom si ukázali trochu více než pouhé modelové příklady, pokusíme se zformátovat ASCII tabulku. Napíšeme tedy program, který načte ze vstupu jméno souboru a do něj uloží znaky 33 - 126 z ASCII tabulky. Na každém řádku bude znak a jeho desítkový, osmičkový a šestnáctkový zápis.
#!/usr/bin/perl
use strict;
my $cil;
print "Kam chcete uložit ASCII tabulku? ";
chomp($cil = <STDIN>);
open CIL, ">$cil" or die "Nelze psát do souboru $cil: $!";
print CIL "ZNAK DEC OCT HEX\n";
for (my $i=33; $i<=126; $i++){
printf CIL ("%4c %3d %3o %3x\n", $i, $i, $i, $i);
}
close CIL;
Celý algoritmus je velmi jednoduchý. Zaměříme se hlavně na funkci printf. Všimněme si, že se tiskne čtyřikrát totéž číslo, pokaždé však jinak zformátované. Poprvé jako znak s velikostí 4. Další 3 sloupce mají velikost 3 a určují pořadí znaku v ASCII tabulce.
Soubor, do kterého bude tabulka uložena se nám takto hezky srovná:
ZNAK DEC OCT HEX ... < 60 74 3c = 61 75 3d > 62 76 3e ? 63 77 3f @ 64 100 40 A 65 101 41 B 66 102 42 C 67 103 43 D 68 104 44 ...
Na dalším příkladu si předvedeme použití sprintf. Vytvoříme tabulku se třemi sloupci. V prvním bude hodnota a v dalších její sinus a kosinus s přesností 5 desetinných míst. Použijeme přitom hodnoty z intervalu <0; 2pi> po osminách.
Tabulka musí mít nějakou hlavičku a rámeček. K tomu budeme ale potřebovat znát předem její šířku. Jak ji ale zjistíme dříve, než vypíšeme hlavičku? Naštěstí je tu funkce sprintf. Nic vypisovat nebudeme, formátovanou hlavičku jen uložíme do proměnné a zjistíme její délku pomocí speciální sekvence %n. Až teď můžeme tisknout horní rámeček.
my $hlava = sprintf("| %11s | %8s | %8s | %n\n", "x", "sin x", "cos x", my $n);
my $line = "+" . "-" x ($n - 3) . "+\n";
print $line, $hlava, $line;
Teď konečně přijde na řadu obsah tabulky. Musíme zachovat šířku buněk.
my $osmina_pi = atan2(1,1) / 2;
for (my $i=0; $i<=16; $i++){
printf ("| %11s | %8.5f | %8.5f |\n", "$i / 8 * pi", sin($i*$osmina_pi),
cos($i*$osmina_pi));
}
Tabulku nakonec musíme uzavřít.
print $line;
Tímto získáváme na standardním výstupu formátovanou tabulku.
Příspívat do diskuze mohou pouze registrovaní uživatelé. |
28.11.2018 23:56 /František Kučera
Prosincový sraz spolku OpenAlt se koná ve středu 5.12.2018 od 16:00 na adrese Zikova 1903/4, Praha 6. Tentokrát navštívíme organizaci CESNET. Na programu jsou dvě přednášky: Distribuované úložiště Ceph (Michal Strnad) a Plně šifrovaný disk na moderním systému (Ondřej Caletka). Následně se přesuneme do některé z nedalekých restaurací, kde budeme pokračovat v diskusi.
Komentářů: 1
12.11.2018 21:28 /Redakce Linuxsoft.cz
22. listopadu 2018 se koná v Praze na Karlově náměstí již pátý ročník konference s tématem Datová centra pro business, která nabídne odpovědi na aktuální a často řešené otázky: Jaké jsou aktuální trendy v oblasti datových center a jak je optimálně využít pro vlastní prospěch? Jak si zajistit odpovídající služby datových center? Podle jakých kritérií vybírat dodavatele služeb? Jak volit vhodné součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně datové centrum spravovat? Jak co nejlépe eliminovat možná rizika? apod. Příznivci LinuxSoftu mohou při registraci uplatnit kód LIN350, který jim přinese zvýhodněné vstupné s 50% slevou.
Přidat komentář
6.11.2018 2:04 /František Kučera
Říjnový pražský sraz spolku OpenAlt se koná v listopadu – již tento čtvrtek – 8. 11. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma umění a technologie, IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
4.10.2018 21:30 /Ondřej Čečák
LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář
18.9.2018 23:30 /František Kučera
Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
9.9.2018 14:15 /Redakce Linuxsoft.cz
20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business.
Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář
12.8.2018 16:58 /František Kučera
Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář
16.7.2018 1:05 /František Kučera
Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.
Přidat komentář
31.7.2023 14:13 /
Linda Graham
iPhone Services
30.11.2022 9:32 /
Kyle McDermott
Hosting download unavailable
13.12.2018 10:57 /
Jan Mareš
Re: zavináč
2.12.2018 23:56 /
František Kučera
Sraz
5.10.2018 17:12 /
Jakub Kuljovsky
Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?