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 02:22 | Nová verze

    D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

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

    Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.

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

    CreepyLink.com je nový zkracovač URL adres, 'díky kterému budou vaše odkazy vypadat tak podezřele, jak je to jen možné'. Například odkaz na abclinuxu.cz tento zkracovač převádí do podoby 'https://netflix.web-safe.link/logger_8oIlgs_free_money.php'. Dle prohlášení autora je CreepyLink alternativou ke zkracovači ShadyURL (repozitář na githubu), který dnes již bohužel není v provozu.

    NUKE GAZA! 🎆 | Komentářů: 2
    včera 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 3
    včera 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

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

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    včera 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 4
    včera 01:55 | Humor

    Microsoft zveřejnil zdrojový kód XAML Studia a uvolnil ho pod MIT licencí. XAML Studio je nástroj ze světa Windows, určený pro tvorbu uživatelského rozhraní aplikací pomocí XAML (Extensible Application Markup Language). Stalo se tak zhruba po osmi letech od prvního prohlášení Microsoftu, že se tento kód chystá zveřejnit.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 01:44 | Zajímavý projekt

    TimeCapsule, 'časová kapsle', je jazykový model trénovaný výhradně na datech z určitých míst a časových období, aby se tak napodobila autentická slovní zásoba, způsob vyjadřování a názory dané doby. Na Hugging face jsou k dispozici modely natrénované na historických textech dostupných v oblasti Londýna mezi lety 1800 až 1875.

    NUKE GAZA! 🎆 | Komentářů: 6
    14.1. 17:55 | Nová verze

    Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (4%)
     (0%)
     (8%)
     (20%)
     (3%)
     (6%)
     (3%)
     (11%)
     (43%)
    Celkem 451 hlasů
     Komentářů: 12, poslední 14.1. 21:12
    Rozcestník

    Dotaz: XML a grep

    25.9.2021 11:43 Paulus | skóre: 15 | Jihlava
    XML a grep
    Přečteno: 470×
    Dobrý den, hledám nějaký konzolový nástroj, který by mi pro XML dovedl vrátit všechny kompletní záznamy, které obsahují hledaný text.

    U přiloženého souboru bych chtěl všechny elementy Subjekt, které budou obsahovat konkrétní IČa. (např 72063271 a 65018826). Ale budu hledat i text, který může mít různé tagy.

    Řešení dotazu:


    Odpovědi

    25.9.2021 11:52 Paulus | skóre: 15 | Jihlava
    Rozbalit Rozbalit vše Re: XML a grep
    Příloha se bohužel nenahrála. Je tady tady (600 kB, jsou to open data z obchodního rejstříku).
    Řešení 2× (d.c., NUKE GAZA! 🎆)
    25.9.2021 12:21 X
    Rozbalit Rozbalit vše Re: XML a grep
    Na zpracovani XML grep fakt ne. Daleko pohodlnejsi je pouzit XML parser a XPATH. Priklad v Pythonu:
    #!/usr/bin/python3
    
    from lxml import etree
    
    with open('zajzdrpo-full-ceske_budejovice-2021.xml', 'rb') as f:
            root = etree.parse(f)
            print(root.xpath('./Subjekt[ico = 4163311]'))
    
    NUKE GAZA! 🎆 avatar 25.9.2021 20:54 NUKE GAZA! 🎆 | skóre: 37 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: XML a grep

    víc krásnější je beautifulsoup která taky umí dělat s lxml parserem hele :O ;D

    NUKE GAZA! 🎆 avatar 25.9.2021 21:03 NUKE GAZA! 🎆 | skóre: 37 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: XML a grep
    #!/usr/bin/env python3
    
    from bs4 import BeautifulSoup
    import argparse
    
    # suběkt jakoby musí mit všecky iča nebo stačí aspoň jedno??????? :O :O
    def najdi_subjekty(subjekty, ica):
        nalezene_subjekty = []
        for sub in subjekty:
            ico = int(sub.find("ico").text)
            if ico in ica:
                nalezene_subjekty.append(sub)
    
        return nalezene_subjekty
    
    
    if __name__ == "__main__":
    
        parser = argparse.ArgumentParser()
        parser.add_argument(
            "-n", "--nazev", help="*.xml co se prohledavaj", required=True, type=str
        )
        parser.add_argument(
            "-i",
            "--ica",
            nargs="+",
            help="všecky ty ica co se jakoze hledaj",
            required=True,
            type=int,
        )
        args = parser.parse_args()
    
        with open(args.nazev, "r") as file:
    
            xml = BeautifulSoup(file.read(), "lxml")
            subjekty = xml.find_all(
                "subjekt"
            )  # musíme napsat malý první písmenko do názvu tagu :O :O
            subs = najdi_subjekty(subjekty, args.ica)
    
            print(f"nalezeno {len(subs)} subektu z celkovyho poctu {len(subjekty)}")
            for sub in subs:
                print("-" * 80)
                print(sub.prettify())
    

    a použije se to jakoby takle třeba

    ./skript.py -n zajzdrpo-full-ceske_budejovice-2021.xml -i 75138514
    Řešení 3× (Aleš Kapica, d.c., NUKE GAZA! 🎆)
    25.9.2021 12:36 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: XML a grep
    xgrep, XQilla nebo XMLStarlet.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    Řešení 1× (NUKE GAZA! 🎆)
    xkucf03 avatar 25.9.2021 21:49 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: XML a grep
    cat zajzdrpo-full-ceske_budejovice-2021.xml \
        | relpipe-in-xmltable \
            --relation 'subjekt' \
                --records '//Subjekt[ico="72063271" or ico="65018826"]' \
                --attribute 'ičo'   string 'ico' \
                --attribute 'název' string 'nazev' \
                --attribute 'xml'   string '.' --mode raw-xml \
        | relpipe-out-tabular | less -RSi
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    25.9.2021 23:19 X
    Rozbalit Rozbalit vše Re: XML a grep
    Suggestions: Bylo by mozne to kompilovat jako samostatnou binarku pod nazvem 'relpipe', ktera by byla parametrizovatelna a zahrnovala vsechny varianty? Takovy "I/O svicarsky nuz", ale na datove soubory? Takto, jak je to dlouhe a nasekane na jednotlive komponenty(relpipe-in-xml,relpipe-in-csv..) je zdlouhave na vypisovani, ale:
    relpipe -in json .. | relpipe -out csv ..
    relpipe --xml ..
    
    bych fakt bral jako hodne super. Zaroven tam nevidim relpipe-in-json. hodou okolnosti XML/CSV/JSON hodne pouzivam a vypisovat to v Python je pro jednorazove ucely otrava. Dobra prace!
    xkucf03 avatar 25.9.2021 23:59 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: XML a grep + Relational pipes
    Bylo by mozne to kompilovat jako samostatnou binarku pod nazvem 'relpipe', ktera by byla parametrizovatelna a zahrnovala vsechny varianty? Takovy "I/O svicarsky nuz", ale na datove soubory? Takto, jak je to dlouhe a nasekane na jednotlive komponenty(relpipe-in-xml,relpipe-in-csv..) je zdlouhave na vypisovani

    Teoreticky by šlo udělat nějaký metamodul, který by sesypal všechny zdrojáky dohromady a udělal z toho jednu binárku (za cenu toho, že to přestane být modulární a bude to záviset na všech knihovnách). Ale spíš jsem si říkal, že by to bylo lepší řešit formou skriptu.

    Ať tak či tak, v obou případech je trochu problém, jak navrhnout to CLI rozhraní. Když je to rozdělené na vstup, transformaci a výstup a oddělené | rourami, tak je jasné, který parametr patří ke kterému příkazu/modulu. Pokud to bude v jednom, tak můžou některé volby kolidovat, nebude to tak přehledné a asi by bylo potřeba k těm parametrům přidat nějaké prefixy.

    Co se týče jednoduchých konverzí z jednoho formátu do druhého, tak mám např. připravený skript 2xml, na který si stačí udělat symlink, např. json2xml, ini2xml, asn12xml atd. A pak má člověk v jednom krátkém příkazu všechno. Bude to zdokumentované v příští verzi. Podobně může vzniknout např. json2csv atd.

    Spíš ale očekávám, že si uživatelé budou psát takové skripty ad-hoc podle svých potřeb, protože napsat to univerzálně je dost komplikované (viz výše).

    Nechávám to zatím otevřené – pokud se najde způsob, jak to udělat dostatečně univerzálně a zároveň přehledně, tak by takový švýcarský nůž byl fajn.

    Zaroven tam nevidim relpipe-in-json. hodou okolnosti XML/CSV/JSON hodne pouzivam a vypisovat to v Python je pro jednorazove ucely otrava.

    V té příští verzi (v0.18) bude relpipe-in-yamlrelpipe-in-yamltable a protože JSON lze považovat za podmnožinu YAMLu, ten parser si poradí i s JSONem a budou tam připravené symlinky relpipe-in-jsonrelpipe-in-jsontable. Ten první očekává pevně danou strukturu (jedna nebo více relací), např.

    "x11_input_device":
      "attribute-metadata":
        - "name": "id"
          "type": "integer"
        - "name": "name"
          "type": "string"
        - "name": "type"
          "type": "string"
      "record":
        - "id": 8
          "name": "Power Button"
          "type": "keyboard"
        - "id": 10
          "name": "Logitech USB Trackball"
          "type": "mouse"
        - "id": 16
          "name": "AT Translated Set 2 keyboard"
          "type": "keyboard"

    nebo:

    {
       "x11_input_device": {
          "attribute-metadata": [
             {
                "name": "id",
                "type": "integer"
             },
             {
                "name": "name",
                "type": "string"
             },
             {
                "name": "type",
                "type": "string"
             }
          ],
          "record": [
             {
                "id": 8,
                "name": "Power Button",
                "type": "keyboard"
             },
             {
                "id": 10,
                "name": "Logitech USB Trackball",
                "type": "mouse"
             },
             {
                "id": 16,
                "name": "AT Translated Set 2 keyboard",
                "type": "keyboard"
             }
          ]
       }
    }

    A ten druhý (relpipe-in-*table) bere libovolnou stromovou strukturu v daném formátu a umožňuje nad ní pouštět XPath dotazy a vygenerovat jednu nebo více relací. První XPath dotaz vybírá záznamy a další XPath dotazy (relativní k výsledkům toho prvního) pak vybírají atributy těch záznamů. V té v0.18 budou podporované kromě standardního XML i YAML, JSON, HTML, INI, ASN.1, CBOR a MIME (e-mailové zprávy). Ten HTML modul se může hodit k vytěžování strukturovaných informací z různých webů – ten parser přečte i nevalidní a všelijak zprasené HTML, postaví se z toho normální DOM a nad ním už lze kouzlit s XPath dotazy, jak je člověk zvyklý z XML.

    Ještě to zbývá trochu doladit a zdokumentovat, ale ve zdrojácích už to je. Předběžný instalační skript: release-v0.18.sh (v Mercurialu ještě není štítek v0.18, takže to bere tip – nejnovější verzi všeho). Pokud to někdo otestuje ještě před vydáním, budu jedině rád.

    Osobně ten asn12xml už nějakou dobu používám pro ladění X.509 certifikátů, P7 podpisů, P12 klíčenek (obecně PKI věcí).

    Dobra prace!

    Díky

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes

    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.