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í
×

    dnes 01:11 | IT novinky

    Společnost PINE64 stojící za telefony PinePhone a PinePhone Pro nebo notebooky Pinebook a Pinebook Pro publikovala na svém blogu březnový souhrn novinek (YouTube). Jednodeskový RISC-V počítač Star64 s SoC StarFive JH-7110 bude v prodeji od 4. dubna.

    Ladislav Hagara | Komentářů: 0
    dnes 00:11 | Nová verze

    Open source modální textový editor Helix, inspirovaný editory Vim, Neovim či Kakoune, byl vydán ve verzi 23.03. Přehled novinek v oznámení na webu a v CHANGELOGu na GitHubu.

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | Humor

    Je tu opět apríl. Společnost Razer představila holící myš Razer Razer. Vědci z CERNu navrhují 25hodinový den. Společnost Elgato představila kolekci Elgato Home. Společnost Nothing Beer (5.1%). Další aprílové novinky například na April Fools' Day On The Web.

    Ladislav Hagara | Komentářů: 0
    včera 12:55 | Komunita

    Před 25 lety byl uvolněn zdrojový kód balíku aplikací Netscape Communicator jako open source (např. dobová zpráva CNET), z čehož vzešel projekt Mozilla – ten si výročí nyní připomíná.

    Fluttershy, yay! | Komentářů: 2
    31.3. 17:11 | Zajímavý software

    Na GOG.com běží Spring Sale. Při té příležitosti lze získat zdarma počítačovou hru Deep Sky Derelicts.

    Ladislav Hagara | Komentářů: 4
    31.3. 14:22 | Nová verze

    Sound Open Firmware, projekt Linux Foundation, open source audio DSP firmware a SDK, byl vydán ve verzi 2.5.0. Přináší podporu platformy Mediatek mt8188 nebo nový audio modul ARIA (Automatic Regressive Input Amplifier Module).

    Ladislav Hagara | Komentářů: 1
    31.3. 12:33 | Nová verze

    Byla vydána nová verze 5.8 programovacího jazyka Swift (Wikipedie). Zdrojové kódy jsou k dispozici na GitHubu. Ke stažení budou oficiální binární balíčky pro Ubuntu 18.04, Ubuntu 20.04, Ubuntu 22.04, CentOS 7, Amazon Linux 2 a Red Hat Universal Base Image 9.

    Ladislav Hagara | Komentářů: 0
    31.3. 12:22 | Nová verze

    Byla vydána nová verze 1.77 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.77 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 7
    31.3. 12:11 | Nová verze

    Byla vydána beta verze Ubuntu 23.04 s kódovým názvem Lunar Lobster. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 23.04 mělo vyjít 20. dubna 2023.

    Ladislav Hagara | Komentářů: 0
    30.3. 17:44 | Nová verze

    Linuxová distribuce OpenMandriva byla vydána ve verzi ROME 23.03. Název ROME říká, že se jedná se o průběžně aktualizovanou (rolling) edici. Stabilní edice nese název Rock, aktuálně OpenMandriva Lx 4.3 Dysprosium.

    Ladislav Hagara | Komentářů: 4
    Chodí vám kočka nebo jiné domácí zvíře po klávesnici?
     (52%)
     (9%)
     (4%)
     (9%)
     (26%)
    Celkem 23 hlasů
     Komentářů: 2, poslední dnes 00:48
    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: 657×
    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.