abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 14:00 | Zajímavý článek

    Byl publikován aktuální přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 12:00 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 12.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 0
    17.7. 18:44 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 155 (pdf) a Hello World 27 (pdf).

    Ladislav Hagara | Komentářů: 1
    17.7. 16:11 | Nová verze

    Hyprland, tj. kompozitor pro Wayland zaměřený na dláždění okny a zároveň grafické efekty, byl vydán ve verzi 0.50.0. Podrobný přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 2
    17.7. 15:55 | Komunita

    Patrick Volkerding oznámil před dvaatřiceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

    Ladislav Hagara | Komentářů: 5
    16.7. 21:22 | IT novinky

    Ministerstvo pro místní rozvoj (MMR) jako první orgán státní správy v Česku spustilo takzvaný „bug bounty“ program pro odhalování bezpečnostních rizik a zranitelných míst ve svých informačních systémech. Za nalezení kritické zranitelnosti nabízí veřejnosti odměnu 1000 eur, v případě vysoké závažnosti je to 500 eur. Program se inspiruje přístupy běžnými v komerčním sektoru nebo ve veřejné sféře v zahraničí.

    Ladislav Hagara | Komentářů: 19
    16.7. 16:22 | IT novinky

    Vláda dne 16. července 2025 schválila návrh nového jednotného vizuálního stylu státní správy. Vytvořilo jej na základě veřejné soutěže studio Najbrt. Náklady na přípravu návrhu a metodiky činily tři miliony korun. Modernizovaný dvouocasý lev vychází z malého státního znaku. Vizuální styl doprovází originální písmo Czechia Sans.

    Ladislav Hagara | Komentářů: 26
    16.7. 15:33 | Upozornění

    Vyhledávač DuckDuckGo je podle webu DownDetector od 2:15 SELČ nedostupný. Opět fungovat začal na několik minut zhruba v 15:15. Další služby nesouvisející přímo s vyhledáváním, jako mapyAI asistent jsou dostupné. Pro některé dotazy během výpadku stále funguje zobrazování například textu z Wikipedie.

    bindiff | Komentářů: 8
    16.7. 13:33 | Bezpečnostní upozornění

    Více než 600 aplikací postavených na PHP frameworku Laravel je zranitelných vůči vzdálenému spuštění libovolného kódu. Útočníci mohou zneužít veřejně uniklé konfigurační klíče APP_KEY (např. z GitHubu). Z více než 260 000 APP_KEY získaných z GitHubu bylo ověřeno, že přes 600 aplikací je zranitelných. Zhruba 63 % úniků pochází z .env souborů, které často obsahují i další citlivé údaje (např. přístupové údaje k databázím nebo cloudovým službám).

    Ladislav Hagara | Komentářů: 5
    16.7. 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 25.07. Přehled novinek se záznamy terminálových sezení v asciinema v oznámení na webu. Detailně v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (27%)
     (7%)
     (3%)
     (0%)
     (1%)
     (4%)
    Celkem 410 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Jak na vnořená pole v php

    4.6.2014 20:17 LM
    Jak na vnořená pole v php
    Přečteno: 714×
    Ahoj, můžete mi prosím poradit, jak prohledávat pole v php?

    když budu mít pole
    $arr['a'] = array('1');
    $arr['b'] = array('2');
    $arr['c'] = array('3');
    $arr['d'] = array('4');
    
    $arr['b']['a'] = array('1');
    $arr['b']['b'] = array('2');
    
    $arr['b']['b']['a'] = array('1');
    $arr['b']['b']['b'] = array('1');
    a když bude
    $dis = array('b');
    tak potřebuji získat hodnotu z
    $arr['b']
    a když bude
    $dis = array('b', 'b');
    tak potřebuji získat hodnotu z
    $arr['b']['b']
    a když bude
    $dis = array('b', 'b', 'b');
    tak potřebuji získat hodnotu z
    $arr['b']['b']['b']
    atd.. Vždy znám jen hloubku toho vnoření, což je počet klíčů v poli $dis. Děkuji za případnou pomoc

    Odpovědi

    4.6.2014 20:41 Kit
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Místo prohledávání polí používáme databáze. V příkladech však žádné vnořené pole nevidím. K čemu to potřebuješ? Třeba se dá obejít i bez toho prohledávání.
    Josef Kufner avatar 4.6.2014 21:21 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Ty se v podstatě snažíš získat vrchol na konci cesty grafem (stromem). Na to je asi nejjednodušší toto:
    $arr = array('a' => array('b' => array('c' => 'Hello')));
    $path = array('a', 'b', 'c');
    
    function walkPath($arr, $path) {
      $p = & $arr;
      foreach ($path as $n) {
        if (array_key_exists($n, $p)) {
          $p = & $p[$n];
        } else {
          throw new \InvalidArgumentException('Invalid path.');
        }
      }
      return $p;
    }
    
    // Toto by melo vypsat 'Hello'
    echo walkPath($arr, $path), "\n";
    Hello world ! Segmentation fault (core dumped)
    4.6.2014 21:40 LM
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Díky za kód ale dívám se co jsi napsal a zjistil jsem, že jsem špatně položil dotaz, SAKRA! Ale snad jen taková drobnost, teda pro odborníka, ne pro mně :-( Potřebuji vypsat vždy všechny, ne jen ten poslední, čili
    a
    ab
    abc
    Děkuji
    4.6.2014 21:51 LM
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Pepo ale stejně tohle
    $arr = array('a' => array('b' => array('c' => 'Hello')));
    není totžné s tím co potřebuji
    $arr = array();
    $arr['a'] = array('a');
    $arr['a']['b'] = array('ab');
    $arr['a']['b']['c'] = array('abc');
    Josef Kufner avatar 4.6.2014 22:54 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Přílohy:
    To nepůjde. Nemůžeš na jedno místo nacpat dvě hodnoty. $arr['a'] buď může obsahovat array('a') (2. řádek) nebo může obsahovat array('b' => array('ab')) (3. řádek).
    $arr = array('a' => array('b' => array('c' => 'Hello')));
    je totéž jako:
    $arr = array();
    $arr['a']['b']['c'] = 'Hello';
    Pokud chceš mít v tom stromu hodnoty i jinde než na listech, tak musíš buď zdvojnásobit vrstvy, nebo určit speciální klíč pro hodnoty:
    $arr = array();
    $arr['a']['#'] = 'a';
    $arr['a']['b']['#'] = 'ab';
    $arr['a']['b']['c']['#'] = 'abc';
    Pak v kterémkoliv vrcholu budeš mít k dispozici hodnotu pod klíčem '#'.

    Tedy celý strom bude vypadat takto -- viz příloha.

    Ale je to takové ošklivé, i když vcelku efektivní.
    Hello world ! Segmentation fault (core dumped)
    4.6.2014 23:02 LM
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Nevím, zda si rozumíme, co příklad? Aktuální situace:

    V systému je mimo jiné takový kousek pole
    $arr                = array();
    $arr['a']           = array('FOO' => 'a',   'BAR' => 'a2');
    $arr['a']['b']      = array('FOO' => 'ab',  'BAR' => 'ab2');
    $arr['a']['b']['c'] = array('FOO' => 'abc', 'BAR' => 'abc2');
    
    $dis = array('a', 'b', 'c');
    
    a potřebuji nadefinovat takové nové pole pro další práci...
    $newarr = array();
    $newarr['a'] = array('FOO' => 'a',   'BAR' => 'a2');
    $newarr['b'] = array('FOO' => 'ab',  'BAR' => 'ab2');
    $newarr['c'] = array('FOO' => 'abc', 'BAR' => 'abc2');
    a ještě výsledky
    echo $newarr['a']['FOO']; //a
    echo $newarr['a']['BAR']; //a2
    echo $newarr['b']['FOO']; //ab
    echo $newarr['b']['BAR']; //ab2
    echo $newarr['c']['FOO']; //abc
    echo $newarr['c']['BAR']; //abc2
    
    Je to lepší ? Díky
    Josef Kufner avatar 4.6.2014 23:18 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Pokud poznáš 'a' of 'FOO', tak to prostě jen rekurzivně projdi.
    Hello world ! Segmentation fault (core dumped)
    4.6.2014 23:21 LM
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Znám pouze jen názvy klíčů uložené v $dis
    $dis = array('a', 'b', 'c');
    Josef Kufner avatar 4.6.2014 23:34 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Takže když je to v $dis, tak je to 'a' a jinak 'FOO'? Pokud ano, tak jednoduchá rekurzivní funkce na průchod stromem ti to pořeší.
    Hello world ! Segmentation fault (core dumped)
    4.6.2014 23:44 LM
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    Nee, v poli $dis jsou uloženy názvy klíčů, klíč s názvem 'a', 'b' a 'c'. Tyto klíče jsou shodné jak pro staré pole $arr, tak pro nově definované pole $newarr.
    5.6.2014 08:56 deadmail
    Rozbalit Rozbalit vše Re: Jak na vnořená pole v php
    V systému je mimo jiné takový kousek pole
    $arr                = array();
    $arr['a']           = array('FOO' => 'a',   'BAR' => 'a2');
    $arr['a']['b']      = array('FOO' => 'ab',  'BAR' => 'ab2');
    $arr['a']['b']['c'] = array('FOO' => 'abc', 'BAR' => 'abc2');
    
    Takze vlastne mate pole:
    Array ( [a] => Array ( [FOO] => a [BAR] => a2 [b] => Array ( [FOO] => ab [BAR] => ab2 [c] => Array ( [FOO] => abc [BAR] => abc2 ) ) ) ) 
    
    Sice nevidim dovod takeho pouzitia, ale potom nieco taketo by to mohlo generovat:
     
     $dis = array('a', 'b', 'c'); 
    
     $newarr = array(); $tmp = $arr;
     foreach($dis as $k) {
      $newarr[$k] = array_intersect_key($tmp[$k], array('FOO' => 0, 'BAR' => 0));
      // $newarr[$k] = array('FOO' => $tmp[$k]['FOO'], 'BAR' => $tmp[$k]['BAR']); //alebo takto
      $tmp = $tmp[$k];
     }
    
     print_r($newarr);
    

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.