LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Perl (14) - Další nástroje pro seznamy

Perl Konečně se podíváme na cyklus foreach, což je jedna z nejpoužívanějších konstrukcí vůbec. Dále je v plánu několik nových funkcí a vstup v souvislosti se seznamy.

29.9.2005 06:00 | Jiří Václavík | Články autora | přečteno 44721×

Procházení pole - cyklus foreach

foreach je cyklus, který se používá v souvislosti s poli, protože umožňuje jejich snadné procházení. Název se skládá ze slov for a each, což už mnoho napovídá o jeho významu. Standardně se foreach zkracuje na for.

@ptaci = ("kos", "vrabec", "papoušek", "datel"); for $klic (@ptaci){ print $klic, "\n"; }

Do proměnné $klic se každou iteraci cyklu přiřadí jedna hodnota pole. Tedy postupně hodnoty $ptaci[0], $ptaci[1], $ptaci[2], $ptaci[3]. Toho užijeme pro výpis dat z pole:

$ perl foreach.pl kos vrabec papoušek datel $

Chceme-li vypisovat hashe, bude se hodit funkce keys, která vrací pole klíčů hashe. Pomocí klíčů totiž lze získat i hodnoty.

%ptaci = (
    "kos"      => "slunečnice",
    "vrabec"   => "slunečnice",
    "papoušek" => "proso",
    "datel"    => "hmyz"
);

for $klic (keys %ptaci){
    print "$ptaci{$klic} je potrava pro $klic\n";
}

Doufám, že jsem nějakého opeřence výběrem jídla neurazil. Každopádně odtud vidíme, že to skutečně funguje:

$ perl foreach.pl slunečnice je potrava pro kos slunečnice je potrava pro vrabec proso je potrava pro papoušek hmyz je potrava pro datel $

Cyklus by měl fungovat stejně i v případě, že přepíšeme for na foreach.

for lze napsat i za příkaz

print "$_, " foreach (1, 2, 3, 4, 5); print "$_, " for (1, 2, 3, 4, 5);

případně za blok.

@p = (1, 2, 3, 4, 5); do {$_ += 10; print "$_, "; } for @p;

Proměnná $_ zatím v tomto seriálu nebyla blíže rozebírána. Bude tak učiněno v příštím díle. Jde o implicitní proměnnou, do které se hodnoty pole postupně přiřazují.

chomp po složkách

Uvedeme-li jako parametr funkce chomp pole, je to jako byste použili funkci chomp na všechny skaláry, které pole obsahuje. Je-li parametrem hash, aplikuje se chomp pouze na hodnoty - tedy klíče zůstanou nezměněny.

Odstraňování hodnot z pole - funkce pop a shift

Jak z názvu vyplývá, pop odstraňuje prvek pole z konce seznamu (ten s nejvyšším indexem) a shift ze začátku. Obě funkce rovněž odstraněnou hodnotu vracejí.

@p = 1 .. 5;

print pop @p;#5
print @p;#1234

shift @p;
print @p;#234

Přidávání hodnot do pole - funkce push a unshift

push přidává prvek na konec seznamu, unshift na začátek. Obě funkce vrací jako návratovou hodnotou hodnotu přidaného prvku.

@p = 1 .. 5;

push @p, 6;
print @p;#123456

unshift @p, 7;
print @p;#7123456

Nahrazování hodnot v poli - funkce splice

Odstraňuje, přidává a nahrazuje prvky v poli. Má 4 parametry.

  • název proměnné typu pole, na kterou se bude příkaz vztahovat
  • pozice, za kterou dojde k manipulaci s polem
  • počet znaků, se kterými bude manipulováno. Nezadáme-li ho, je koncová pozice automaticky nastavena na konec řetězce
  • seznam prvků, které budou přidány

Mějme pole čísel:

$, = ", ";
@p = 1 .. 20;

Odstraňme prvky 8 - 11:

@odstranene = splice(@p, 7, 4);

Jak vidíme, vrací funkce jako návratovou hodnotu pole odstraněných prvků:

print @odstranene;#8, 9, 10, 11

Samotné pole @p obsahuje:

print @p;#1, 2, 3, 4, 5, 6, 7, 12, 13, 14, 15, 16, 17, 18, 19, 20

Odstraňme všechny prvky od prvku s hodnotou 13:

splice(@p, 8);
print @p;#1, 2, 3, 4, 5, 6, 7, 12

Prvky s indexy 1 a 2 nahradíme jinými. Lze přidat jiný počet prvků, než kolik jich je odebráno. Též je možné zadat jako třetí parametr 0 - v tom případě se budou prvky jen přidávat.

splice(@p, 1, 1, 2000, 2002, 2004, 2006);
print @p;#1, 2000, 2002, 2004, 2006, 3, 4, 5, 6, 7, 12

A nakonec smažme všechny prvky:

splice @p;
print @p;#""

Pole a vstup

Když jsme načítali vstup ve skalárním kontextu, vždy jsme získali jen jeden řádek ze zdroje dat. Přiřazujeme-li zdroj dat do pole, vytvoří se tolik prvků, kolik mají data řádků. Hodnotami prvků jsou právě řádky.

Modifikujme náš příklad s českými králi ze 7. dílu tak, aby se vypsali všichni, kteří jsou v souboru uloženi. Připomeňme si datový soubor kralove:

Přemysl Otakar I. 1197-1230
Václav I. 1230-1253
Přemysl Otakar II. 1253-1278

Jen zaměníme skalární proměnnou za pole:

#!/usr/bin/perl
use strict;

my @radky = <>;
print @radky;

A dostaneme všechny tři řádky.

$./kralove.pl kralove
Přemysl Otakar I. 1197-1230
Václav I. 1230-1253
Přemysl Otakar II. 1253-1278
$

Rozdělení řetězce do prvků pole - funkce split

split rozdělí řetězec na několik podřetězců a ty uloží do seznamu. Funkce hledá v řetězci výskyty oddělovače (první parametr). Oddělovačem je regulární výraz, ale zatím ho chápejme jako obyčejný řetězec, který je uvozen lomítky. Výskyty oddělovačů určují právě začátek a konec výsledných podřetězců. Oddělovač se ale v podřetězcích neobjevuje. Druhým parametrem je samotný řetězec. Lze uvést i třetí parametr, který určuje, kolik nejvíce může podřetězců být. Po vyhledání daného počtu oddělovačů je posledním podřetězcem celý text za posledním výskytem, přičemž nezáleží, zda tam nějaký výskyt ještě není.

$veta = "Perl letos slaví 18. narozeniny!";

($slovo1, $slovo2, $slovo3) = split(/ /, $veta);
print $slovo1;#Perl
print $slovo2;#letos
print $slovo3;#slaví

Oddělovačem byla mezera - tímto způsobem získáme (ve většině případů) jednotlivá slova. Ve výsledných podřetězcích již mezery nebudou.

@vsechna_slova = split(/ /, $veta, 4);

Na posledním řádku byl text rozdělen na 4 podřetězce a ty jsou následně přiřazeny do pole. Každý podřetězec bude hodnotou prvku. Pokračujme ale v kódu:

foreach $slovo (@vsechna_slova){
    print "$slovo, ";
}

Každou iterací bylo vytisknuto jedno slovo věty a za ním čárka. Při páté iteraci se vytiskl zbytek textu.

Ještě jednou dnes dostanou slovo králové. Uděláme z řádků věty tak, že před období vlády přidáme text. Předpokládejme, že období je vždy za poslední mezerou v řádku.

while ($radek = <>){
    chomp $radek;
    @p = split(/ /, $radek);
    $obdobi = pop @p;
    print "@p vládl v letech $obdobi.\n";
}

Sám algoritmus funguje tak, že rozdělíme řádek mezerami, poslední prvek (období) přesuneme do jiné proměnné a můžeme tisknout.

$ perl kralove.pl kralove
Přemysl Otakar I. vládl v letech 1197-1230.
Václav I. vládl v letech 1230-1253.
Přemysl Otakar II. vládl v letech 1253-1278.
$

Spojování prvků do řetězce - funkce join

Zatímco split řetězce rozděluje, join je naopak spojuje. Jeho použití velmi podobné jako u split. Prvním parametrem je spojovač, který bude vložen do výsledného řetězce mezi každé dvě hodnoty seznamu.

$rada[0] = 0;
for ($i=1; $i<10; $i++){
    $rada[$i] = $i + $rada[$i-1];
}

print join(" ", @rada); #0 1 3 6 10 15 21 28 36 45
print join(", ", @rada); #0, 1, 3, 6, 10, 15, 21, 28, 36, 45
print join(" *** ", @rada); #0 *** 1 *** 3 *** 6 *** 10 *** 15 *** 21 *** 28 *** 36 *** 45
print join("", @rada); #0136101521283645

Verze pro tisk

pridej.cz

 

DISKUZE

Malé doplnění 29.9.2005 10:13 Hynek (Pichi) Vychodil
A ještě něco 29.9.2005 10:31 Hynek (Pichi) Vychodil




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

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ář

18.6.2018 0:43 /František Kučera
Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.
Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

5.10.2018 17:12 / Jakub Kuljovsky
Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?

20.9.2018 10:04 / Jan Ober
Jaký kurz a software by jste doporučili pro začínajcího kodéra?

20.9.2018 10:00 / Jan Ober
Re: Gimp

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2018) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze