![]() ![]() |
ARCHIV |
||||||||||||||||||||||||||||||||||||||||
![]() ![]() ![]() ![]() ![]() ![]() |
|
Modifikátor | Popis |
---|---|
:P5, :Perl5 | zapne starou verzi regulárních výrazů |
:ratchet | bez backtrackingu |
:i, :ignorecase | nehledí na velikost písmen |
:m, :ignoremark | nehledí na různé druhy interpunkce |
:g, :global | provede porovnání vícekrát |
:ov, :overlap | provede porovnávání vícekrát, ale navíc i s překrývajícími se výskyty |
:s, :sigspace | bílé znaky nebudou ignorovány |
:7x, :x(7) | matchovat 7× |
:7th, :nth(7) | 7. match |
:nth(2,4,6...*) | matchuje sudé výskyty |
:ex, :exhaustive | matchuje všemi způsoby (přesvědčit se lze v proměnné @()) |
Perl 6 navíc umožňuje definici vlastních modifikátorů. Pro obsáhlejší informace o modifikátorech lze doporučit nahlédnutí do dokumentace.
Klíčové slovo grammar deklaruje jmenný prostor pro pravidla. Názorněji si představme grammar jako analogii package. package obsahuje metody, podobně grammar obsahuje nějaké regulární výrazy.
Uveďme si hodně umělý příklad na validaci emailové adresy, na kterém ale uvidíme, jak se výše uvedené používá. Používá se Backus-Naurova normální forma.
grammar Email::Simple {
regex email {<uzivatel> @ <server> \. <koncovka>}
token uzivatel {[\w\.\-]+}
token server {[\w\.\-]+}
token koncovka {cz|com|info}
}
Nyní se můžeme vně jmenného prostoru například na regex email odvolávat jako na Email::Simple::email. Jak tedy ověříme správnost emailu?
if $email ~~ /Email::Simple::email/ {
say "OK";
}
Podívejme se, jaké nové operátory nám Perl 6 přináší. Již jsme se s některými setkali v minulém dílu a nyní se věnujme dalším. Na úvod je dobré se alespoň letmo podívat na kompletní přehled operátorů, kde uvidíme desítky úplně nových.
Nově lze zřetězit operátory pro porovnávání. Lze tak vytvořit následující podmínku.
if (1 <= 5 < 10){
say "OK";
}
Operátor X je tzv. metaoperátor, což je velmi zajímavá věc. Základní použití je následující.
say ((1, 2) X (4, 5)).perl; # tiskne ((1, 3), (1, 4), (2, 3), (2, 4))
Použití však je daleko širší, neboť lze specifikovat, jakým operátorem mají interagovat každé dva prvky. Implicitně je to čárka. Lze ale použít i jiné operátory. Operátor uvedeme za X.
say ((1, 2) X~ (3, 4)).perl # tiskne ("13", "14", "23", "24")
say ((1, 2) X* (3, 4)).perl # tiskne (3, 4, 6, 8)
say ((1, 2) X== (3, 4)).perl # tiskne (Bool::False, Bool::False, Bool::False, Bool::False)
Stojí za zamyšlení, jak bychom libovolný z uvedených příkladů napsali v Perlu 5.
Pro operace po složkách lze stejným způsobem použít operátor Z. Vždy spolu interagují ntý prvek v pravém seznamu a ntý prvek v levém seznamu. Podívejme se, jak efektně můžeme v Perlu 6 sčítat vektory nebo tvořit hashe.
say ((1, 2) Z+ (3, 4)).perl # tiskne (4, 6)
%hash = @zavodnici Z=> @jejich_osobni_rekordy # vytvoří hash
V Perlu 6 máme následující typy operátorů.
Operátor s operandy | Typ |
---|---|
7 + 7 | infix |
+7 | prefix |
$p++ | postfix |
<7 8 9> | circumfix |
@p[7] | postcircumfix |
Jak bychom například vytvořili a použili operátor pro zaokrouhlování (za předpokladu, že máme funkci round)?
multi sub prefix:<°> (Rat $arg) {
return round($arg);
}
say °3.14;
Měli bychom ale také specifikovat prioritu právě definovaného operátoru a asociaci. To uděláme v případě priority pomocí slov equiv, tighter, looser vzhledem k již existujícím operátorům a pomocí assoc s parametrem left, right nebo none. Například takto.
multi sub infix:<°> is equiv(&infix:<*>){ ... }
multi sub infix:<°> is tighter(&infix:<*>){ ... }
multi sub infix:<°> is looser(&infix:<*>){ ... }
multi sub infix:<°> is assoc("left"){ ... }
Pomocí multi můžeme také přetěžovat již existující operátory.
Perl 6 zavádí nový třítečkový operátor pro rozsahy s líným vyhodnocováním. Díky němu můžeme elegantně generovat různé aritmetické a geometrické posloupnosti.
1, 2, 4 ... * # generuje posloupnost mocnin dvou
1, 3, 9 ... * # generuje posloupnost mocnin tří
0, 2 ... * # generuje posloupnost sudých čísel
1, 3 ... * # generuje posloupnost lichých čísel
5, 4 ... * # generuje posloupnost čísel od 5 do minus nekonečna
1.1, 1.2 ... 5.3 # generuje posloupnost čísel od 1,1 do 5,3 s krokem 0.1
Co když chceme omezenou posloupnost, ale nevíme z hlavy poslední člen? Co například mocniny dvou do 10000?
1, 2, 4 ... 10000
To bohužel fungovat nebude, protože vygenerovaný člen je vždy porovnáván s posledním na rovnost. Příklad tedy vygeneruje nekonečnou posloupnost. Avšak existuje trik, který ji ukončit dokáže, i když poslední člen nevíme.
1, 2, 4 ... * >= 10000
Místo >= lze použít i jiný operátor. Tato konstrukce je zkratkou za uzávěr -> $a {$a >= 10000}. Totéž lze nezkráceně napsat takto.
1, 2, 4 ... -> $a {$a >= 10000}
Když chceme generovat posloupnost, která není ani aritmetická ani geometrická, musíme ji definovat jako lambda funkci. Vzpomeňme si, jak jsme psali podprogram na výpočet Fibonacciho posloupnosti. Takto ji přiřadíme do pole v Perlu 6.
my @fibonacci := 0, 1, -> $a, $b {$a + $b} ... *;
S trochou magie lze totéž přepsat takto.
my @fibonacci := 0, 1, * + * ...^ *
Výsledek po operaci ... lze samozřejmě přiřadit do pole.
@mocniny_dvou = 1, 2, 4 ... *;
Prvních 6 elementů vytiskneme takto.
say @mocniny_dvou[^6];
Podívejme se v bodech na několik zajímavých změn.
Nejsou žádné diskuzní příspěvky u dané položky. 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?