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

> Perl (8) - Některé základní vestavěné funkce

Perl Vestavěné funkce usnadňují základní úkony. Udělejme si nyní malý přehled, abychom poznali alespoň některé základní možnosti. Dále v průběhu seriálu budeme postupně poznávat další.

2.5.2005 07:00 | Jiří Václavík | Články autora | přečteno 41398×

Jako snad v každém rozšířeném programovacím jazyce jsou i součástí Perlu funkce. Funkce je nějaký program uvnitř programu, kterému je obvykle předáván parametr nebo parametry (pravidlem to ale není) a na základě něj vrátí funkce určitou hodnotu, vytiskne něco na výstup nebo provede jinou činnost. Protože mají funkce návratovou hodnotu, jsou to v kontextu volání výrazy. Nejméně dvě funkce jsme již poznali: print a chomp.

Parametr funkce se zapisuje do závorek. Jestliže závorky neuvedeme, Perl většinou sám pozná, co argumentem je a co ne. Proto můžeme závorky téměř vždy vynechat. Tuto konvenci ostatně u print používáme stále a stejně tak ji budeme používat u dalších vestavěných funkcí.

Později budeme psát naše vlastní funkce. Při volání takových funkcí závorky zpravidla používat budeme. To samé platí o jinak získaných funkcích, které byly do našeho kódu nějak exportované.

Matematické funkce

Začněme u funkcí, které jsou jako funkce chápány v matematice.

Absolutní hodnota potřetí

Posledně jsme vylepšovali náš příklad na výpočet absolutní hodnoty tak, aby byl interaktivní. Absolutní hodnota je příklad jako kovaný pro použití funkce. Místo zdlouhavého testování, zda je vstupní číslo záporné nebo není, použijeme předdefinovanou funkci abs:

#!/usr/bin/perl
use strict;

my $hodnota;
print "Zadejte hodnotu:";
chomp ($hodnota = <STDIN>);

$hodnota = abs $hodnota;
print "Absolutní hodnota zadaného čísla je $hodnota\n";

Funkce abs přijímá jako parametr číslo a vrací jeho absolutní hodnotu. Tu lze získat přiřazením této funkce do proměnné. Pokud chceme návratovou hodnotu funkce přímo vytisknout, uveďme ji jako parametr funkce print.

Goniometrické funkce

FunkcePopisPříkladVýsledek
sin(hodnota_v_rad)Vrací sinus parametrusin 3.1415920.000...
cos(hodnota_v_rad)Vrací kosinus parametrucos 3.141592-0.999...
atan2(x, y)Vrací arkus tangens podílu x / yatan2 (1, 1)0.785...

Víme, že tan-1 (1) = pi / 4. Po vynásobení rovnice číslem 4 tak získáme Ludolfovo číslo. Příklad také ilustruje nepovinnost psát závorky i v případech, kdy má funkce více argumentů.

print 4 * atan2 1, 1; #3.14159265358979

Další matematické funkce

FunkcePopisPříkladVýsledek
log(hodnota)Přirozený logaritmus (základem je Eulerovo číslo)log 10
exp(exponent)Vrací Eulerovo číslo umocněné exponentemexp 12.718...
sqrt(číslo)druhá odmocnina číslasqrt 42
int(číslo)Vrací celou část čísla (parametru)int 4.74
oct(číslo_v_8kové_soustavě)Převádí z 8kové do 10kové soustavyoct "777"511
hex(číslo_v_16kové_soustavě)Převádí z 16kové do 10kové soustavyhex "ff"255

Funkce pro práci s řetězci

FunkcePopisPříkladVýsledek
chomp(řetězec)Odstraní případný znak \n./td>$p = "abc\n";chomp $pabc
chop(řetězec)Odstraní poslední znak řetězce$p = "abc";chop $pab
uc(řetězec)Převede v řetězci malá písmena na velkáuc "AbCdE"ABCDE
lc(řetězec)Převede v řetězci velká písmena na malálc "AbCdE"abcde
ucfirst(řetězec)Převede 1. písmeno na velkéuc "abcde"Abcde
lcfirst(řetězec)Převede 1. písmeno na malélc "ABCDE"aBCDE
length(řetězec)Počet znaků v řetězcilength "abcde"5
chr(ASCII_kód)Vrátí znak náležící ASCII kóduchr 100d
ord(znak)Vrátí ASCII kódord "d"100

Funkce substr - ořezávání a nahrazování v řetězcích

substr je velmi obecná a často používaná funkce. Pracuje s podřetězci - vyhledává je v řetězcích, případně je nahrazuje jinými. Řadu speciálních případů volání lze nahradit voláním jednodušších funkcí, které postupně poznáme. Často také lze s řetězcem manipulovat jako s polem, což bývá často rychlejší.

Funkce substr má celkem 4 parametry. Zde je schéma volání:

substr(řetězec, od, kolik, náhrada);

První parametr určuje řetězec, se kterým bude substr pracovat. Druhým parametrem je pozice, která určuje začátek podřetězce. Další parametr definuje, kolik znaků bude obsahovat podřetězec. Posledním parametrem říkáme, čím chceme vybraný podřetězec nahradit. Povinné jsou jen první dva argumenty.

print substr "Pchjongjang", 3;
#Vráceno je vše od 3. pozice napravo - tedy jongjang

print substr "Pchjongjang", 3, 4;
#Vráceny jsou 4 po sobě jdoucí znaky, z nichž 1. je na pravo od 3. pozice - tedy jong

$slovo = "Pchjongjang";
substr $slovo, 3, 4, "jing";
print $slovo;
#Pchjingjang
#Jestliže chceme nahrazovat, je nutné předat funkci řetězec v proměnné - ne jen řetězec (který je vlastně neměnnou konstanou).

$slovo = "Pchjongjang";
substr $slovo, 3, 4, "";
print $slovo;
#Pchjang

Hodnoty od a kolik mohou být také záporné. U od to znamená první pozici na konci atd., u kolik určujeme, kolik znaků má zůstat do konce řetězce.

$slovo = "Pchjongjang";
print substr $slovo, -4, 3;
#jan

$slovo = "Pchjongjang";
print substr $slovo, -4, -3;
#j

$slovo = "Pchjongjang";
substr $slovo, -4, 4, "jing";
print $slovo;
#Pchjongjing
#Jsou nahrazeny 4 znaky vpravo za 4. pozicí od konce

$slovo = "Pchjongjang";
substr $slovo, -11, 9, "Beiji";
print $slovo;
#Beijing

substr má ještě jednu možnost zápisu. Paradoxem je, že se v něm funkce vyskytuje nalevo od operátoru přiřazení. To je napříč programovacími jazyky naprosto unikátní jev. Tyto zápisy mají na řetězec stejný efekt:

substr(retezec, od, kolik, náhrada);
substr(retezec, od, kolik) = náhrada;

Takhle to pak vypadá:

$slovo = "Pchjongjang";
substr($slovo, 3, 4) = "XXX";
print $slovo; #PchXXXjang

$slovo = "Pchjongjang";
$f = (substr($slovo, 3, 4) = "XXX");
print $slovo;#PchXXXjang
print $f;#XXXj

Opět jde ale o ukázku, kterou je dobré vidět a zase na ni zapomenout, neboť bychom si zbytečně znepřehledňovali kód.

Hledání podřetězců

Obě funkce mají 3 parametry:

index(řetězec, hledaný_podřetězec, od);
rindex(řetězec, hledaný_podřetězec, od);

Funkce index a rindex vyhledávají podřetězce uvnitř řetězců. Vracejí pozici prvního znaku hledaného podřetězce v řetězci. Poslední parametr je nepovinný a specifikuje pozici, od které začíná hledání. Není-li v řetězci podřetězec nalezen, vrací funkce -1. index hledá první výskyt, rindex poslední výskyt.

print index  "Zimbabwe", "w";#6
print rindex "Zimbabwe", "w"#6
print index  "Zimbabwe", "b";#3
print rindex "Zimbabwe", "b"#5
print index  "Zimbabwe", "b", 4; #5
print rindex "Zimbabwe", "b", 3;#3
print rindex "Zimbabwe", "x"#-1
print rindex "Zimbabwe", "Z"#0

Funkce die

Uvedení funkce die znamená výjimku a konec programu. Ty příkazy, které jsou za die, se neprovádí. Jako parametr je možné uvést hlášku, která se zobrazí na výstupu.

if ($selhani == 1){
    die "Nepovedlo se zapsat data!\n";
}

Pokud parametr neukončíme koncem řádku, automaticky se vypíše i místo, kde byla funkce die volána.

Zatím se této funkci nebudeme věnovat podrobněji. Brzy na ni dozajista opět narazíme.

Funkce exit

die a exit mají podobný význam. die, jak už víme, ukončí okamžitě program. exit také. Rozdíl je v tom, kdy se tyto funkce volají. Nám bude zatím stačit, že exit nevydá žádné hlášení o chybě (nemá žádný výstup).

Definovanost proměnných

Funkce defined rozlišuje nedefinovanou hodnotu od všech ostatních - včetně 0 nebo prázdného řetězce. V případě nedefinované hodnoty vrací false.

(Pseudo)náhoda

Naučme se generovat náhodné číslo z rovnoměrného rozdělení. Nejprve musíme inicializovat generátor náhodných čísel. K tomu máme příkaz srand bez parametrů.

  srand;

V tuto chvíli spustil Perl stopky. Zbývá z nich zachytit nějakou hodnotu.

  $i = rand 983;

Do proměnné $i bylo přiřazeno náhodné desetinné číslo z intervalu [0; 983]. Neuvedeme-li mez, vrací funkce hodnoty z intervalu [0; 1].

Chceme-li realizace z diskrétního rovnoměrného rozdělení, dosáhneme toho zaokrouhlením jednotlivých realizací. Například pro generování z dvouprvkové množiny {0, 1} (nebo-li true/false) bychom psali toto.

  $i = int rand 2;

Příklad - řešení rovnice 2. stupně

Programovat se nelze naučit čtením manuálů nebo opisováním kódu z učebnic, ale psaním svých programů. Je vhodné, aby si každý, kdo se chce naučit programovat, zkusil sám něco napsat.

Zde je příležitost. Zadání úlohy zní: Napište program, který na základě zadání koeficientů ze standartního vstupu spočítá kořeny kvadratické rovnice v množině reálných čísel a vypíše je na výstup (nezapomeňte na všechny podmínky).

Řešení

Takto rozsáhlý příklad jsme zatím nedělali. Sám algoritmus není obtížný, ale je třeba si průběžně uvědomovat, co je v kterém kroku potřeba udělat a co vše může nastat.

U všech větších příkladů se v seriálu budeme snažit postupovat tak, jak bychom ho pravděpodobně řešili na základě intuice. V návodech pro začátečníky by zdrojový kód neměl být vysvětlován řádek po řádku, aniž by byly přiblíženy myšlenky, kterými se k výslednému kódu dospělo.

Tento příklad je ale jedním z těch jednodušších, které lze řešit i metodou od prvního řádku k poslednímu. Takže nejdříve načteme data ze vstupu:

#!/usr/bin/perl
use strict;

my ($a, $b, $c, $x1, $x2);

print "Zadejte koeficienty kvadratické rovnice ax^2 + bx + c = 0\n";
print "a = "; $a = <STDIN>;
print "b = "; $b = <STDIN>;
print "c = "; $c = <STDIN>;

Poté už můžeme začít s výpočtem. Vzorec x1 = (-b + odmocnina(b^2 - 4*a*c)) / (2*a) popř. x2 = (-b - odmocnina(b^2 - 4*a*c)) / (2*a) jistě každý zná. Je nutné si uvědomit podmínky řešitelnosti - tj. dávat si pozor jestli neodmocňujeme záporné číslo, nedělíme nulou nebo se nemění počet řešení. Nejprve ošetříme podmínkami speciální případy a poté dopíšeme obecné řešení.

Ošetřme tedy případ, kdy je diskriminant záporný (pro větší názornost používám zápis $b ** 2 - 4 * $a * $c < 0, ale samozřejmě lze nerovnici upravit a použít $b ** 2 < 4 * $a * $c):

if ($b ** 2 - 4 * $a * $c < 0){ 
    die "V množině reálných čísel nemá rovnice řešení.\n";
}

Pokud je diskriminant roven nule, řešení je jen jedno:

if ($b ** 2 - 4 * $a * $c == 0 and $a != 0){ 
    $x1 = $b / (2 * $a);
    die "Řešením dané rovnice je $x1.\n";
}

Další speciální situace nastane, je-li koeficient a = 0. V tom případě jde o lineární rovnici. Do podmínky zahrňme i test koeficientu b, protože to je další speciální případ.

if ($a == 0 and $b != 0){
    $x1 = -$c / $b;
    die "Řešením dané rovnice je $x1.\n";
}

Je-li totiž i koeficient b = 0, jedná se o rovnici nultého stupně. Ta má jako řešení buď všechna reálná čísla a nebo řešení nemá.

if ($a == 0 and $b == 0 and $c != 0){ 
    die "V množině reálných čísel nemá rovnice řešení.\n";
}

if ($a == 0 and $b == 0 and $c == 0){ 
    die "Řešením rovnice jsou všechna reálná čísla.\n";
}

Všechny speciální případy jsou vyřešeny, tak se můžeme pustit do obecného řešení. Sem se program dostane pouze pokud nevyhověly vstupní hodnoty některému předchozímu případu.

$x1 = ($b + sqrt($b ** 2 - 4 * $a * $c)) / (2 * $a);
$x2 = ($b - sqrt($b ** 2 - 4 * $a * $c)) / (2 * $a);

print "Řešením dané rovnice je $x1 a $x2.\n";


Poznámka: Samozřejmě to není jediné řešení problému. Další možností by mohla být například podmínka if ($a == 0){ ... } else { ... }, v jejíž větvích by byly další podmínky..

Zde máme výsledek:

$ ./kvadraticka_rovnice.pl
Zadejte koeficienty kvadratické rovnice ax^2 + bx + c = 0
a = 5
b = 2
c = 5
V množině reálných čísel nemá rovnice řešení
$ ./kvadraticka_rovnice.pl
Zadejte koeficienty kvadratické rovnice ax^2 + bx + c = 0
a = 2
b = 5
c = 3
Řešením dané rovnice je 1.5 a 1.
$ ./kvadraticka_rovnice.pl
Zadejte koeficienty kvadratické rovnice ax^2 + bx + c = 0
a = 5
b = 10
c = 5
Řešením dané rovnice je 1.
$ ./kvadraticka_rovnice.pl
Zadejte koeficienty kvadratické rovnice ax^2 + bx + c = 0
a = sh
b = hgf
c = shgfd
Řešením rovnice jsou všechna reálná čísla.
$

V posledním případě byly řetězce automaticky konvertovány na čísla.

Verze pro tisk

pridej.cz

 

DISKUZE

chyba v kvadratické rovnici 29.10.2012 16:59 Jan Knížek




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

5.3.2017 19:12 /Redakce Linuxsoft.cz
PR: 23. března proběhne v Praze konferenci na téma Cloud computing v praxi. Hlavními tématy jsou: Nejžhavější trendy v oblasti cloudu a cloudových řešení, Moderní cloudové služby, Infrastruktura současných cloudů, Efektivní využití cloudu, Nástrahy cloudových řešení a jak se jim vyhnout.
Přidat komentář

27.2.2017 22:12 /František Kučera
Pozvánka na 137. sraz OpenAlt – Praha: Tentokrát jsme si pro vás připravili neobvyklou akci. Ve středu 1.3. v 17:30 nás přivítá sdružení CZ.NIC ve svých prostorách v Milešovské ulici číslo 5 na Praze 3, kde si pro nás připravili krátkou prezentaci jejich činnosti. Následně navštívíme jejich datacentrum pod Žižkovskou věží. Provedou nás prostory, které jsou běžnému smrtelníkovi nedostupné!
Po ukončení prohlídky se všchni odebereme do hostince U vodoucha, Jagelonská 21, Praha 3 pochutnat si na některém z vybraných piv či dát si něco na zub. Rezervaci máme od 19:30, heslo je OpenAlt.
Ale pozor! Do prostor datového centra máme omezený přístup, dostane se tam pouze 10 lidí! Takže kdo přijde dříve, ten má přednost, a občanky s sebou! Kdo nebude chtít na prohlídku datového centra, může se pomalu přesunout do hostince U vodoucha a u nepřeberné nabídky piv počkat na ostatní.
Přidat komentář

18.1.2017 0:49 /František Kučera
Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.
Přidat komentář

8.1.2017 17:51 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 19. ledna od 18:30 v pražském hackerspacu Brmlab. Tentokrát je tématem srazu ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. K vidění bude mechanická klávesnice dasKeyboard, trackball Logitech nebo grafický tablet (a velký touchpad) Wacom. Přineste i vy ukázat svoje zajímavé klávesnice a další HW. V 18:20 je sraz před budovou, v 18:30 jdeme společně dovnitř, je tedy dobré přijít včas. Podle zájmu se později přesuneme do nějaké restaurace v okolí.
Přidat komentář

1.12.2016 22:13 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.
Komentářů: 1

4.9.2016 20:13 /Pavel `Goldenfish' Kysilka
PR: Dne 22.9.2016 proběhne v Praze konference Cloud computing v praxi. Tématy bude např. nejnovější trendy v oblasti cloudu a cloudových řešení, provozování ERP v cloudu, o hostování různých typů softwaru, ale třeba i o zálohování dat nabízeném podnikům formou služby.
Přidat komentář

1.9.2016 11:27 /Honza Javorek
Česká konference o Pythonu, PyCon CZ, stále hledá přednášející skrz dobrovolné přihlášky. Máte-li zajímavé téma, neváhejte a zkuste jej přihlásit, uzávěrka je již 12. září. Konference letos přijímá i přednášky v češtině a nabízí pomoc s přípravou začínajícím speakerům. Řečníci mají navíc vstup zadarmo! Více na webu.
Přidat komentář

27.8.2016 8:55 /Delujek
Dnes po 4 letech komunitního vývoje vyšla diaspora 0.6.0.0
diaspora* je open-source, distribuovaná sociální síť s důrazem na soukromý
Více v oficiálním blog-postu
Přidat komentář

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

> Poslední diskuze

24.3.2017 11:54 / Hui
country cottages

16.3.2017 16:33 / BezvaDesign.cz
Re: Hledám grafika do teamu

9.3.2017 11:44 / Jaromir Obr
Re: chyba

18.1.2017 20:18 / martin horky
Spolupraca linuxu a microsoftu

17.1.2017 9:57 / Pavel Hrubeš
Re: Externí USB televizní karta

Více ...

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