Funkce používané při vyhodnocování výrazů: Porovnání verzí

Z K.A.P.
Skočit na navigaciSkočit na vyhledávání
 
(Není zobrazeno 21 mezilehlých verzí od 2 dalších uživatelů.)
Řádek 22: Řádek 22:
 
{| class="wikitable" border=0
 
{| class="wikitable" border=0
 
|-valign=top
 
|-valign=top
|width=180|'''char(x)'''||převede číslo na znak dle kódu ASCII (x:0 až 255)
+
|width=170|'''char(x)'''||převede číslo na znak dle kódu ASCII (x:0 až 255)
 
|-valign=top
 
|-valign=top
 
|'''code(ret)'''||převede první znak řetězce ret na číslo dle kódu ASCII
 
|'''code(ret)'''||převede první znak řetězce ret na číslo dle kódu ASCII
Řádek 39: Řádek 39:
 
|-valign=top
 
|-valign=top
 
|'''getVar(prom)'''||vrací hodnotu proměnné prom, která byla předtím uložena pomocí funkce SetVar; funkce může vrátit buď řetězec nebo číslo v závislosti na tom, jaká hodnota byla uložena pomocí SetVar
 
|'''getVar(prom)'''||vrací hodnotu proměnné prom, která byla předtím uložena pomocí funkce SetVar; funkce může vrátit buď řetězec nebo číslo v závislosti na tom, jaká hodnota byla uložena pomocí SetVar
 +
|-valign=top
 +
|'''hash(ret,n)'''||vrací hodnotu ret zkonvertovanou pomocí algoritmu MD5. Pokud je n=0, pak výsledný text navíc převeden na textový hexadecimální formát (32 znaků)
 
|-valign=top
 
|-valign=top
 
|'''left(ret,n)'''||vrací prvních n znaků řetězce ret (zleva)
 
|'''left(ret,n)'''||vrací prvních n znaků řetězce ret (zleva)
Řádek 59: Řádek 61:
 
|-valign=top
 
|-valign=top
 
|'''replace(ret1,poz,n,ret2)'''||nahradí část řetězce ret1 od pozice poz o délce n řetězcem ret2
 
|'''replace(ret1,poz,n,ret2)'''||nahradí část řetězce ret1 od pozice poz o délce n řetězcem ret2
 +
|-valign=top
 +
|'''replaceStr(ret,PuvText,NovyText,Podm)'''||nahrazení jednoho textu v řetězci znaků jiným textem; Údaj Podm zadejte jako součet následujících hodnot (tj. číslo 0 až 7).<br/> +1 : nahrazuje všechny výskyty řetězce PuvText;<br/> +2 : při hledání řetězce PuvText se ignoruje velikost písmen;<br/> +4 : řetězec znaků ret obsahuje znaky v kódování Windows-1250 (použije se jen ve spojení s +2); funkce doplněna 22.3.2019
 
|-valign=top
 
|-valign=top
 
|'''right(ret,n)'''||vrací posledních n znaků řetězce ret (zprava)
 
|'''right(ret,n)'''||vrací posledních n znaků řetězce ret (zprava)
Řádek 70: Řádek 74:
 
|'''setVar(prom, x)'''||uloží hodnotu x proměnné prom do seznamu proměnných (x může být číslo nebo řetězec). Funkce vždy vrací jako hodnotu prázdný řetězec
 
|'''setVar(prom, x)'''||uloží hodnotu x proměnné prom do seznamu proměnných (x může být číslo nebo řetězec). Funkce vždy vrací jako hodnotu prázdný řetězec
 
|-valign=top
 
|-valign=top
|'''str(x,n,d)'''||převede číslo x na řetězec s d desetin. místy v n znacích
+
|'''str(x,n,d)'''||převede číslo x na řetězec o n znacích s d desetin. místy
 +
|-valign=top
 +
|'''str(x)'''|| převede číslo x na řetězec znaků, který neobsahuje úvodní mezery
 
|-valign=top
 
|-valign=top
 
|'''strCarka(ret)'''||doplní řetězec ret (o řetězci se předpokládá, že obsahuje textové vyjádření celého nebo desetinného čísla) oddělovacími znaky tak, aby byly odděleny tisíce, milióny, atd.
 
|'''strCarka(ret)'''||doplní řetězec ret (o řetězci se předpokládá, že obsahuje textové vyjádření celého nebo desetinného čísla) oddělovacími znaky tak, aby byly odděleny tisíce, milióny, atd.
 
|-valign=top
 
|-valign=top
|'''strCena(x,n)'''||převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla; číslo je doplněno mezerami zleva tak, aby výsledná délka řetězce byla n znaků. Číslo je zobrazeno nejméně na 2 desetinná místa
+
|'''strCurr(x,n)''' <br/>nebo '''strCena(x,n)'''||převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla; číslo je doplněno mezerami zleva tak, aby výsledná délka řetězce byla n znaků. Číslo je zobrazeno nejméně na 2 desetinná místa
 
|-valign=top
 
|-valign=top
|'''strCislo(x,n)'''||převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla; číslo je doplněno mezerami zleva tak, aby výsledná délka řetězce byla n znaků. Číslo je zobrazeno s maximálně 6 desetinnými místy
+
|'''strNum(x,n)''' <br/>nebo '''strCislo(x,n)'''||převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla; číslo je doplněno mezerami zleva tak, aby výsledná délka řetězce byla n znaků. Číslo je zobrazeno s maximálně 6 desetinnými místy
 
|-valign=top
 
|-valign=top
 
|'''string(x,n)'''||převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla s n desetinnými místy
 
|'''string(x,n)'''||převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla s n desetinnými místy
 
|-valign=top
 
|-valign=top
 
|'''StrFlags(P,ret,n)'''||vrací řetězec znaků délky n, který vznikne maskováním jednotlivých znaků řetězce ret odpovídajícími bity čísla P (vhodné pro zobrazování příznaků)
 
|'''StrFlags(P,ret,n)'''||vrací řetězec znaků délky n, který vznikne maskováním jednotlivých znaků řetězce ret odpovídajícími bity čísla P (vhodné pro zobrazování příznaků)
 +
|-valign=top
 +
|'''StrToXML(s)'''||naformátuje řetězec znaků s tak, aby změnil znaky, které nejsou povolené v XML, na speciální náhradní značky,např. &amp; nahradí '& a m p ;'
 
|-valign=top
 
|-valign=top
 
|'''StrW(n)'''||převede číslo od 0 do 65535 do dvoubytové interní podoby
 
|'''StrW(n)'''||převede číslo od 0 do 65535 do dvoubytové interní podoby
Řádek 109: Řádek 117:
 
|'''day(dat)'''||z čísla představujícího datum zjistí pořadové číslo dne v měsíci
 
|'''day(dat)'''||z čísla představujícího datum zjistí pořadové číslo dne v měsíci
 
|-valign=top
 
|-valign=top
|width=180|'''FormatDate(dat, format)'''||formátuje datum dle řetězce format; údaj format může obsahovat d pro den, dd pro den s případnou nulou na začátku, m pro měsíc, mm pro měsíc s případnou nulou na začátku, yy pro poslední 2 číslice z roku, yyyy pro čtyřmístné označení roku (např. „dd.mm.yyyy“). Údaj dat může být buď řetězec znaků ve formátu „den/měsíc/rok“ nebo hodnota vrácená funkcí DateValue.
+
|width=170|'''FormatDate(dat, format)'''||formátuje datum dle řetězce format; údaj format může obsahovat d pro den, dd pro den s případnou nulou na začátku, m pro měsíc, mm pro měsíc s případnou nulou na začátku, yy pro poslední 2 číslice z roku, yyyy pro čtyřmístné označení roku (např. „dd.mm.yyyy“). Údaj dat může být buď řetězec znaků ve formátu „den/měsíc/rok“ nebo hodnota vrácená funkcí DateValue.
 
|-valign=top
 
|-valign=top
 
|'''month(dat)'''||zjistí číslo měsíce
 
|'''month(dat)'''||zjistí číslo měsíce
Řádek 118: Řádek 126:
 
|-valign=top
 
|-valign=top
 
|'''year(dat)'''||zjistí rok z datumu dat
 
|'''year(dat)'''||zjistí rok z datumu dat
 +
|-valign=top
 +
|'''GetTime'''||vrací aktuální čas v textovém formátu hh:mm:ss (funkce doplněna 25.8.2011)
 +
|-valign=top
 +
|'''FormatTime(cas, format)'''||formátuje čas dle řetězce format (hh .. hodiny, mm nebo nn .. minuty, ss .. sekundy) (funkce doplněna 25.8.2011)
 
|}
 
|}
  
Řádek 137: Řádek 149:
 
|'''MaskOr(x,y)'''||vrací bitovou disjunkci dvou celých čísel
 
|'''MaskOr(x,y)'''||vrací bitovou disjunkci dvou celých čísel
 
|-valign=top
 
|-valign=top
|'''MatchMask(m,d)'''||vrací hodnotu 1, pokud textový řetězec d vyhovuje masce specifikované řetězcem m. Rozlišují se malá a velká písmena, diakritika i mezery na začátku nebo na konci textu. Maska m může obsahovat speciální znaky: znak * pro označení skupiny libovolných znaků (včetně prázdného textu) a znak ? pro označení právě jednoho znaku. Příklady: MatchMask("*black", Nazev) bude vracet 1 pro Nazev končící slovem black, MatchMask("*black*white*", Nazev) bude vracet 1 pokud Nazev bude obsahovat slovo black následované slovem white, MatchMask("???black*", Nazev) bude vracet 1 pokud Nazev má na čtvrté pozici počínaje slovo black a končí libovolným textem.
+
|width=170|'''MatchMask(m,d)'''||vrací hodnotu 1, pokud textový řetězec d vyhovuje masce specifikované řetězcem m, jinak vrací hodnotu 0. Rozlišují se malá a velká písmena, diakritika i mezery na začátku nebo na konci textu. Maska m může obsahovat speciální znaky: znak * pro označení skupiny libovolných znaků (včetně prázdného textu) a znak ? pro označení právě jednoho znaku. Příklady: MatchMask("*black", Nazev) bude vracet 1 pro Nazev končící slovem black, MatchMask("*black*white*", Nazev) bude vracet 1 pokud Nazev bude obsahovat slovo black následované slovem white, MatchMask("???black*", Nazev) bude vracet 1 pokud Nazev má na čtvrté pozici počínaje slovo black a končí libovolným textem.
 +
|-valign=top
 +
|'''MatchMasks(m,d)'''||První parametr m musí být vyplněn seznamem masek, jimž má vyhovovat údaj d. V parametru m lze použít znaky * jako zástupný znak pro libovolnou skupinu znaků, znaky ? jako zástupný znak pro právě jeden znak. Lze použít současně více masek. V tom případě je nutné jednotlivé masky oddělit znakem /. Pokud maska začíná znakem !, tak se chápe jako negativní maska (čili pokud údaj d vyhovuje této negativní masce, tak je celý výraz vyhodnocen jako nevyhovující. Funkce vrací jako výsledek pořadí masky (číslováno od 0), které vyhovuje d. Funkce vrací záporné číslo pokud žádná maska nevyhovuje (popř. vrací záporné pořadí negativní masky - číslováno od -2).
 
|}
 
|}

Aktuální verze z 7. 9. 2020, 14:49

Matematické

abs(x) vrací absolutní hodnotu čísla x
int(x) vrací celou část čísla x
mod(x,y) vrací zbytek po dělení celého čísla x celým číslem y
rand vrací náhodné číslo z intervalu 0 až 1
round(x,n) vrací číslo x zaokrouhlené na n desetinných míst; n může být z intervalu -9 až 9



Řetězcové funkce používané při zadávání výrazů

char(x) převede číslo na znak dle kódu ASCII (x:0 až 255)
code(ret) převede první znak řetězce ret na číslo dle kódu ASCII
conv(ret,cp) převede řetězec ret na zvolenou kódovou stránku cp (0..ASCII, 1..Kamenický, 2..ASCII2, 3..LATIN2, 4..Windows 1250)
DelAll(ret) vymaže všechny mezery řetězce ret
DelLeft(ret) vymaže všechny mezery zleva
DelRight(ret) vymaže všechny mezery zprava
EnumStr(ret,n,x) vrací n-tou část řetězce ret; n je počítáno od 0;třetí parametr x je nepovinný a pokud není nadefinován, tak se automaticky použije oddělovací znak "/". Jednotlivé části řetězce ret musí být odděleny znakem x např. "první/druhý/třetí/čtvrtý"
find(ret1,ret2,n) hledá výskyt řetězce ret1 v řetězci ret2, hledání začíná od pozice n; vrací vyhledanou pozici nebo 0, pokud se řetězec ret1 nevyskytuje v řetězci ret2
getVar(prom) vrací hodnotu proměnné prom, která byla předtím uložena pomocí funkce SetVar; funkce může vrátit buď řetězec nebo číslo v závislosti na tom, jaká hodnota byla uložena pomocí SetVar
hash(ret,n) vrací hodnotu ret zkonvertovanou pomocí algoritmu MD5. Pokud je n=0, pak výsledný text navíc převeden na textový hexadecimální formát (32 znaků)
left(ret,n) vrací prvních n znaků řetězce ret (zleva)
length(ret) vrací délku řetězce ret (počet znaků); funkce je identická s funkcí len
lower(ret) převede velká písmena v řetězci ret na malá (pouze u písmen anglické abecedy)
mid(ret,poz,n) vrací část řetězce ret od pozice poz o délce n znaků
PadL(ret, n, z) doplní řetězec ret znakem z zleva na délku n znaků
pos(ret1,ret2) vrací pozici řetězce ret1 v řetězci ret2, nebo 0, pokud se řetězec ret1 v řetězci ret2 nevyskytuje
PosUp(ret1,ret2) vrací pozici řetězce ret1 v řetězci ret2 bez ohledu na malá a velká písmena, nebo 0, pokud se řetězec ret1 v řetězci ret2 nevyskytuje
proper(ret) upraví řetězec ret tak, aby každé samostatné slovo začínalo velkým písmenem (vhodné pro úpravu jmen)
repeat(ret,n) vrací n krát zopakovaný řetězec ret
replace(ret1,poz,n,ret2) nahradí část řetězce ret1 od pozice poz o délce n řetězcem ret2
replaceStr(ret,PuvText,NovyText,Podm) nahrazení jednoho textu v řetězci znaků jiným textem; Údaj Podm zadejte jako součet následujících hodnot (tj. číslo 0 až 7).
+1 : nahrazuje všechny výskyty řetězce PuvText;
+2 : při hledání řetězce PuvText se ignoruje velikost písmen;
+4 : řetězec znaků ret obsahuje znaky v kódování Windows-1250 (použije se jen ve spojení s +2); funkce doplněna 22.3.2019
right(ret,n) vrací posledních n znaků řetězce ret (zprava)
setCenter(ret,n) doplní řetězec ret mezerami zleva a zprava, tak aby výsledný řetězec byl dlouhý n znaků a původní řetězec byl uprostřed
setLeft(ret,n) odstraní z řetězce ret mezery zleva a doplní řetězec mezerami zprava tak, aby výsledný řetězec byl dlouhý n znaků
setRight(ret,n) odstraní z řetězce ret mezery zprava a doplní řetězec mezerami zleva tak, aby výsledný řetězec byl dlouhý n znaků
setVar(prom, x) uloží hodnotu x proměnné prom do seznamu proměnných (x může být číslo nebo řetězec). Funkce vždy vrací jako hodnotu prázdný řetězec
str(x,n,d) převede číslo x na řetězec o n znacích s d desetin. místy
str(x) převede číslo x na řetězec znaků, který neobsahuje úvodní mezery
strCarka(ret) doplní řetězec ret (o řetězci se předpokládá, že obsahuje textové vyjádření celého nebo desetinného čísla) oddělovacími znaky tak, aby byly odděleny tisíce, milióny, atd.
strCurr(x,n)
nebo strCena(x,n)
převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla; číslo je doplněno mezerami zleva tak, aby výsledná délka řetězce byla n znaků. Číslo je zobrazeno nejméně na 2 desetinná místa
strNum(x,n)
nebo strCislo(x,n)
převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla; číslo je doplněno mezerami zleva tak, aby výsledná délka řetězce byla n znaků. Číslo je zobrazeno s maximálně 6 desetinnými místy
string(x,n) převede číslo x na řetězec znaků tak, že výsledný řetězec obsahuje textové vyjádření čísla s n desetinnými místy
StrFlags(P,ret,n) vrací řetězec znaků délky n, který vznikne maskováním jednotlivých znaků řetězce ret odpovídajícími bity čísla P (vhodné pro zobrazování příznaků)
StrToXML(s) naformátuje řetězec znaků s tak, aby změnil znaky, které nejsou povolené v XML, na speciální náhradní značky,např. & nahradí '& a m p ;'
StrW(n) převede číslo od 0 do 65535 do dvoubytové interní podoby
trim(ret) odstraní z řetězce ret nadbytečné mezery
upper(ret) převede řetězec ret na velká písmena (včetně znaků s diakritickými znaky)
using(ret,n) doplní řetězec mezerami zprava tak, aby výsledný řetězec byl dlouhý n znaků
value(ret) převede řetězec ret na číslo; pokud se při převodu vyskytne chyba, pak je vrácena 0; funkce je identická s funkcí val
WinFmt(ret) naformátuje číslo uložené v řetězci ret tak, aby bylo zpracovatelné standardními programy Windows (odstraní mezery, nahradí desetinnou tečku čárkou)

Funkce pro zpracování datumu

Parametr dat je číslo představující datum; lze ho získat funkcemi date, datevalue a now

strDate(dat) převede datum na řetězec znaků (do tvaru DD/MM/RR)
date(rrrr,mm,dd) převede rok, měsíc a den na číslo představující toto datum
DateValue(ret) převede řetězec tvaru DD/MM/RR na číslo představující datum; místo funkce DateValue je možné alternativně použít stejně pracující funkci DV()
day(dat) z čísla představujícího datum zjistí pořadové číslo dne v měsíci
FormatDate(dat, format) formátuje datum dle řetězce format; údaj format může obsahovat d pro den, dd pro den s případnou nulou na začátku, m pro měsíc, mm pro měsíc s případnou nulou na začátku, yy pro poslední 2 číslice z roku, yyyy pro čtyřmístné označení roku (např. „dd.mm.yyyy“). Údaj dat může být buď řetězec znaků ve formátu „den/měsíc/rok“ nebo hodnota vrácená funkcí DateValue.
month(dat) zjistí číslo měsíce
now vrací aktuální datum
weekday(dat) vrací pořadové číslo dne v týdnu dle anglického kalendáře (0..neděle, 1..pondělí, ...)
year(dat) zjistí rok z datumu dat
GetTime vrací aktuální čas v textovém formátu hh:mm:ss (funkce doplněna 25.8.2011)
FormatTime(cas, format) formátuje čas dle řetězce format (hh .. hodiny, mm nebo nn .. minuty, ss .. sekundy) (funkce doplněna 25.8.2011)

Logické funkce používané při zadávání výrazů

false vrací hodnotu 0
if(podm,x,y) pokud je splněna podmínka podm (není rovna 0), pak je vrácena hodnota x, jinak je vrácena hodnota y; výrazy x a y mohou být číselného i řetězcového typu, ale typ musí v obou případech být stejný
isNumber(p) vrací 1 pokud je p číselného typu, jinak vrací 0
true vrací hodnotu 1
MaskAnd(x,y) vrací bitovou konjunkci dvou celých čísel
MaskOr(x,y) vrací bitovou disjunkci dvou celých čísel
MatchMask(m,d) vrací hodnotu 1, pokud textový řetězec d vyhovuje masce specifikované řetězcem m, jinak vrací hodnotu 0. Rozlišují se malá a velká písmena, diakritika i mezery na začátku nebo na konci textu. Maska m může obsahovat speciální znaky: znak * pro označení skupiny libovolných znaků (včetně prázdného textu) a znak ? pro označení právě jednoho znaku. Příklady: MatchMask("*black", Nazev) bude vracet 1 pro Nazev končící slovem black, MatchMask("*black*white*", Nazev) bude vracet 1 pokud Nazev bude obsahovat slovo black následované slovem white, MatchMask("???black*", Nazev) bude vracet 1 pokud Nazev má na čtvrté pozici počínaje slovo black a končí libovolným textem.
MatchMasks(m,d) První parametr m musí být vyplněn seznamem masek, jimž má vyhovovat údaj d. V parametru m lze použít znaky * jako zástupný znak pro libovolnou skupinu znaků, znaky ? jako zástupný znak pro právě jeden znak. Lze použít současně více masek. V tom případě je nutné jednotlivé masky oddělit znakem /. Pokud maska začíná znakem !, tak se chápe jako negativní maska (čili pokud údaj d vyhovuje této negativní masce, tak je celý výraz vyhodnocen jako nevyhovující. Funkce vrací jako výsledek pořadí masky (číslováno od 0), které vyhovuje d. Funkce vrací záporné číslo pokud žádná maska nevyhovuje (popř. vrací záporné pořadí negativní masky - číslováno od -2).