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 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    dnes 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 0
    dnes 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    dnes 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 26
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (34%)
     (2%)
     (14%)
     (2%)
     (2%)
     (2%)
     (16%)
     (16%)
     (12%)
    Celkem 104 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: Perl + XPath rovnaké tágy

    10.12.2006 22:28 dusan456 | skóre: 12 | Poprad
    Perl + XPath rovnaké tágy
    Přečteno: 275×
    Chcem použiť XPath na extraktovanie textu z XML dokumentu. Takto nejako vypadá môj aaa.xml
    <document>
    <result>
    <A>
    nieco1
    </A>
    <B>
    <text>
    nieco2
    </text>
    </B>
    <B>
    <text>
    nieco3
    </text>
    </B>
    </result>
    <result>
    ...
    </document>

    a takto nejako vypadá môj pelrový skript na extraktovanie
    use strict;
    use DBI;
    use XML::XPath;
    use XML::XPath::XMLParser;

    my $dbh = DBI->connect ("DBI:mysql:test", "root", "", { RaiseError => 1, PrintError => 0});
    my $xp = XML::XPath->new (filename => "aaa.xml");
    my $nodelist = $xp->find ("//result");
    foreach my $row ($nodelist->get_nodelist ())
    {
    $dbh->do (
    "INSERT INTO tabulka (a, b_prva, b_druha) VALUES (?,?,?)",
    undef,
    $row->find ("A")->string_value (),
    $row->find ("B/text")->string_value (),
    $row->find ("B/text")->string_value ()
    );

    }
    $dbh->disconnect ();

    Problem je v tom, že B/text je obsiahnuté dva razy v tom XML dokumente a do tabulky vloží vždy prvú hodnotu aj do druhého a aj do tretieho stĺpca. Vie niekto poradiť? Ďakujem

    Odpovědi

    10.12.2006 23:26 Petr
    Rozbalit Rozbalit vše Re: Perl + XPath rovnaké tágy
    Např. pomocí "B[1]/text" a "B[2]/text".
    10.12.2006 23:32 dusan456 | skóre: 12 | Poprad
    Rozbalit Rozbalit vše Re: Perl + XPath rovnaké tágy
    Perfektneee, dakujem.

    Ja som skusal "B/text[1]" a "B/text[2]", preto mi to nefungovalo, tak som myslel, ze v tom to nebude.
    Fuky avatar 10.12.2006 23:33 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Perl + XPath rovnaké tágy

    use strict;
    use DBI;
    use XML::XPath;
    
    my $xp = XML::XPath->new(filename => 'soubor.xml');
    
    foreach my $row ($xp->findnodes('//result')) {
      print $row->find('A')->string_value;
    
      foreach my $row ($xp->findnodes('//result/B')) {
        print $row->find('text')->string_value;
      }
    }
    

    9.4.2009 22:39 Jezza
    Rozbalit Rozbalit vše Re: Perl + XPath rovnaké tágy

    Mam takovyto xml soubor: fi.muni.cz/~xjezek2/temp/forum.xml

     

    Chci z nej dostat urcita data a pouzivam na to upraveny skript z tohoto fora:

    use strict;
    use DBI;
    use XML::XPath;

    my $xp = XML::XPath->new(filename => 'def.xml');

    foreach my $row ($xp->findnodes('//oval_definitions/definitions/definition/metadata')) {
      print "title = ";
        print $row->find('title')->string_value;
     
        foreach my $row ($xp->findnodes('//oval_definitions/definitions/definition/metadata/affected')) {
      print "platform = ";
        print $row->find('platform')->string_value; ## jak na vice platfotm?    Jak ulozit hodnotu tagu do promente, jak vypsat atribut tagu?
       
        }
    }

     

    Potreboval bych dostat informace z tagu platform, ktery je v jedne urovni vicekrat.

    Dale bych se chtel zeptat, jak ulozit do promenne tato ziskana data misto toho, ze se tisknout...zkousel jsem to ruzne, ale pise by to chyby.

    Posledni dotaz je, lze ziska nejen hodnotu tagu, ale i jeho atributy, jako je treba i tagu <definition> comment a id?

    Predem diky

    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.