Pole v PHP
1.
Klíče
1.1
číselné
1.2
asociativní // $stat["CR"] = "Praha";
2.
Vícerozměrná pole
2.1
$staty = array("CR" => array("hlavni_mesto" => "Praha", "popoulace" => "10 mil."););
3.
Výstup polí
3.1
print_r
3.1.1
odešle na výstup obsah jakékoliv proměnné, umí zobrazit obsah pole i objektu do čitelného formátu
3.1.2
nepovinný parametr return (true) vrátí výstup volajícímu, ne na standardní výstup
4.
Jak se vytvoří pole
4.1
$stat[0] = "CR"; $stat[1] = "SR"; // funguje i u asociativních polí
4.2
$stat[] = "CR"; // pouze číselné vzestupné indexy
4.3
array()
4.4
list()
4.4.1
v jediné operaci přiřadí do proměnných hodnoty extrahované z nějakého pole
4.4.2
$pole[] = "Matous"; $pole[] = "Havlena": list($jmeno, $prijmeni) = $pole;
4.4.3
Velmi užitečné pro vytahování dat z databáze!!!
4.5
range(od, do, po_kolika(nepovinne))
4.5.1
vytvoří posloupnost pole, počínaje hodnotou od do hodnoty do, muze jit i po delsich krocich
5.
Test na pole
5.1
is_array()
6.
Přidávání a odstraňování prvků pole
6.1
$arrayname[]
6.1.1
viz předtím jak se přímo vytvoří pole
6.2
array_push($pole, "a", "b", ...)
6.2.1
přídá proměnné na konec pole $pole
6.3
array_pop($pole)
6.3.1
vrátí poslední prvek
6.4
array_shift($pole)
6.4.1
vrátí první prvek
6.5
array_unshift($pole, "a", "b", ...)
6.5.1
přidává prvky na začátek pole $pole
6.6
array_pad($pole, $delka, $vych_hodnota)
6.6.1
zvětší délku pole specifikovanou argumentem delka a naplni ho hodnotou vych_hodnota
6.6.2
pokud délka menší než pole, nic se neprovede
6.6.3
kladna vych_hodnota doplni pole vpravo, zaporna vlevo
7.
Vyhledávání prvků v poli
7.1
in_array($jehla, $kupka_sena, strict(nepoviné))
7.1.1
hledá $jehlu jako hodnotu v poli $kupka_sena, vrací true nebo false
7.1.2
strict říká, zda brát v úvahu i typ
7.2
array_keys($pole, $hodnota(nepovinný))
7.2.1
vrátí pole všech klíčů, je-li uvedena $hodnota, tak se vrátí pouze ty klíče, které odpovídají dané hodnotě
7.3
array_key_exists($klic, $pole)
7.3.1
vrátí true pokud najde v poli daný klíč
7.4
array_values($pole)
7.4.1
vrátí všechny hodnoty v poli do pole s číselnými indexy
7.5
array_search($jehla, $kupka_sena, strict(1 - nepovinný))
7.5.1
hledá v poli $kupka_sena hodnotu $jehla a vrátí její klíč nebo false
8.
Procházení polí
8.1
key($pole)
8.1.1
vrátí klíč umístěný na aktuální pozici ukazatele
8.2
reset($pole)
8.2.1
nastaví ukazatel zpět na začátek
8.3
each($pole)
8.3.1
vrátí aktuální dvojici klíč/hodnota a posune ukazatel o jednu pozici, pokud se ukazatel před voláním nacházel na konci pole, vrátí FALSE
8.3.2
Vrácené pole se skládá ze 4 klíčů (0 a key, 1 a value)
8.4
current($pole)
8.4.1
vrátí hodnotu pole nacházející se na aktuální pozici ukazatele
8.5
end($pole)
8.5.1
posune ukazatel na poslední prvek a vrátí jeho pozici
8.6
next($pole)
8.6.1
posune ukazatel dopředu a vrátí hodnotu pole
8.7
prev($pole)
8.7.1
posune ukazatel zpět dozadu a vrátí hodnotu pole na dané pozici, pokud je ukazatel před voláním na 1. pozici, vrátí false
8.8
array_walk(&$pole, "funkce", $userdata(nepovinné))
8.8.1
Předá každý prvek z pole array uživatelsky definované fci funkce.
8.8.2
Pokud chceme upravovat dvojice klíč/hodnota, musíme je předávat ve fci odkazem.
8.8.3
Uživatelsky definovaná fce musí přebírat 2 vstupní parametry. 1. reprezentuje aktuální hodnotu a 2. aktuální klíč. Jestliže uvedem i nepovinný parametr userdata, pak se jeho hodnota předá jako 3. parametr.
8.8.4
Dobré pro desinfekci dat předaných formulářem.
8.9
array_reverse($pole, preserve_keys(true - nepovinné))
8.9.1
Obrátí pořadí prvků v poli. Je-li preserve_keys na true, zachovají se původní klíče, jinak každá nová hodnota bude mít klíč hodnoty, která se zde nacházela předtím.
8.10
array_flip($pole)
8.10.1
Prohodí klíče a hodnoty.
9.
Zjištění velikosti a jedinečných hodnot pole
9.1
count($pole, mode(1 - nepovinný))
9.1.1
Vrátí celkový počet hodnot. Je-li zapnutý nepovinný parametr mode na 1, bude se počítat i rekursivně (tedy i vícerozměrná pole - pozor, i pole typu "a" => array(..) se počítá za prvek).
9.2
sizeof()
9.2.1
to samé co count()
9.3
array_count_values($pole)
9.3.1
Vrátí pole z asociativních dvojic klíč/hodnota. Každý klíč reprezentuje nějakou hodnotu nalezenou v poli, jemu odpovídající hodnota označuje četnost tohoto klíče (jako hodnota).
9.4
array_unique($pole)
9.4.1
Odstraní všechny duplicitní hodnoty v poli. Vrátí pole skládající se pouze z jedinečných hodnot.
10.
Setřídění prvků polí
10.1
Všechny algoritmy pracují v souladu s pravidly angličtiny. Pokud chceme svá místní nastavení, musíme nastavit pomocí fce setlocale().
10.2
sort($pole, sort_flags(nepovinné))
10.2.1
Uspořádá "na místě" prvky od nejnižší po nejvyšší hodnoty.
10.2.2
sort_flags modifikuje chování fce: SORT_NUMERIC - číselně SORT_REGULAT - podle ASCII SORT_STRING - nejlépe odpovídá lidským představám
10.2.3
Neuchová asociace klíč/hodnota. Pak pomůže asort().
10.3
natsort($pole)
10.3.1
uspořádá takto: picture1, picture2, picture10, picture20
10.4
natcasesort($pole)
10.4.1
Identická s natsort(), ale nerozlišuje velikost písmen.
10.5
rsort($pole, sort_flags(nepovinné))
10.5.1
Jako sort(), ale seřadí prvky opačně.
10.6
asort($pole, sort_flags(nepovinné))
10.6.1
Jako sort(), ale zachová asociace klíč/hodnota.
10.7
array_multisort($pole1, poradi, typ, $pole2, poradi, typ, ...)
10.7.1
Setřídí několik polí naráz a umí také třídit mnoha způsoby vícerozměrné pole. Vrátí true pokud úspěšná.
10.7.2
Za každým polem mohou následovat přepínače, které určují způsob třídení.
10.7.3
2 druhy přepínačů: pořadí a typ
10.7.3.1
pořadí: SORT_ASC, SORT_DESC
10.7.3.2
typ: SORT_REGULAR, SORT_NUMERIC, SORT_STRING
10.8
arsort($pole, sort_flags(nepovinné))
10.8.1
Podobně jako asort() udržuje asociace klíč/hodnota. Setřídí však pole v opačném pořadí.
10.9
ksort($pole, sort_flags(nepovinné))
10.9.1
Setřídí vstupní pole podle jeho klíčů. Vrátí true v případě úspěchu, jinak false.
10.10
krsort($pole, sort_flags(nepovinné))
10.10.1
Jako ksort(), ale v opačném pořadí.
10.11
usort(&$pole, "funkce")
10.11.1
Setřídí pole podle uživatelsky definovaného porovnávacího algoritmu zakompovaného do nějaké fce.
10.11.2
Uživatelsky definovaná fce musí přebírat 2 argumenty a musí vrácet záporné (v případě že je 1. argument menší jak 2.), 0 (stejné), nebo kladné číslo.
11.
Kombinace, sloučení, extrakce a porovnání
11.1
array_combine($klice, $hodnoty)
11.1.1
Vytvoří nové pole z daných klíčů a hodnot. Obě pole musí být stejně velké a neprázdné.
11.2
array_merge($pole1, $pole2, ...)
11.2.1
Sloučí pole dohromady a vrátí jediné pole. Jednotlivá pole se budou připojovat za sebou.
11.2.2
Pokud vstupní pole obsahuje řetězcový klíč, který už ve výsledném poli existuje, přepíše se novou hodnotou. To však neplatí pro číselné klíče, při nich se přídá do pole.
11.3
array_merge_recursive($pole1, $pole2, ...)
11.3.1
Stejně jako array_merge(), akorát pokud při slučování existují stejné klíče, sloučí se do jednoho pole a vytvoří se pole vícerozměrné.
11.4
array_slice($pole, $offset, $length(nepovinné))
11.4.1
Vrátí část pole počínaje klíčem offset a pozicí offset + length. Obě hodnoty zase mohou být záporné i kladné (intuitivně domyslíme). Pokud není length, skončí posledním prvkem pole.
11.5
array_splice($pole, $offset, $length(nepovinné), $replacement(nepovinné))
11.5.1
Odstraní z pole všechny prvky počínaje pozicí odpovídající hodnotě offset a konče pozicí offset + length. Vrátí odstraněné prvky ve formě pole.
11.5.2
Nepovinný parametr replacement udává pole, které nahradí odstraňovaný segment.
11.6
array_intersect($pole1, $pole2, ...)
11.6.1
Vrátí průnik polí (bere v potaz hodnoty). Klíče se zachovají.
11.7
array_intersect_assoc($pole1, $pole2, ...)
11.7.1
Stejně jako array_intersect(), ale bere v úvahu při porovnávání i klíče.
11.8
array_diff($pole1, $pole2, ...)
11.8.1
Vrátí ty hodnoty z $pole1, které nejsou v žádném z ostatních vstupních polí. Opak array_intersect().
11.9
array_diff_assoc($pole1, $pole2, ...)
11.9.1
Stejně jako array_diff(), akorát bere v úvahu i klíče.
12.
Ostatní
12.1
array_rand($pole, num_entries(nepovinné))
12.1.1
Vrátí jeden nebo více klíčů ze vstupního pole. Neuvede-li se num_entries, vrátí se jeden náhodně vybraný klíč.
12.2
shuffle($pole)
12.2.1
Náhodně přeskládá prvky v poli.
12.3
array_sum($pole)
12.3.1
Sečte všechny hodnoty pole a vrátí celkový součet. Najdou-li se v poli hodnoty jiného typu než číselného, ignorují se.
12.4
array_chunk($pole, $size, preserve_keys(nepovinné))
12.4.1
Rozčlení pole na vícerozměrné pole skládající se z několika menších polí obsahujících size prvků.
12.4.2
Není-li velikost dělitelná beze zbytku, bude poslední pole obsahovat méně než size prvků.
12.4.3
Zapne-li se preserve_keys, zachovají se klíče hodnot.