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 22:22 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube).

    Ladislav Hagara | Komentářů: 0
    včera 19:11 | IT novinky

    Provozovatel čínské sociální sítě TikTok dostal v Evropské unii pokutu 530 milionů eur (13,2 miliardy Kč) za nedostatky při ochraně osobních údajů. Ve svém oznámení to dnes uvedla irská Komise pro ochranu údajů (DPC), která jedná jménem EU. Zároveň TikToku nařídila, že pokud správu dat neuvede do šesti měsíců do souladu s požadavky, musí přestat posílat data o unijních uživatelích do Číny. TikTok uvedl, že se proti rozhodnutí odvolá.

    Ladislav Hagara | Komentářů: 2
    včera 11:22 | Zajímavý projekt

    Společnost JetBrains uvolnila Mellum, tj. svůj velký jazykový model (LLM) pro vývojáře, jako open source. Mellum podporuje programovací jazyky Java, Kotlin, Python, Go, PHP, C, C++, C#, JavaScript, TypeScript, CSS, HTML, Rust a Ruby.

    Ladislav Hagara | Komentářů: 0
    včera 09:11 | Bezpečnostní upozornění

    Vývojáři Kali Linuxu upozorňují na nový klíč pro podepisování balíčků. K původnímu klíči ztratili přístup.

    Ladislav Hagara | Komentářů: 0
    1.5. 20:00 | Komunita

    V březnu loňského roku přestal být Redis svobodný. Společnost Redis Labs jej přelicencovala z licence BSD na nesvobodné licence Redis Source Available License (RSALv2) a Server Side Public License (SSPLv1). Hned o pár dní později vznikly svobodné forky Redisu s názvy Valkey a Redict. Dnes bylo oznámeno, že Redis je opět svobodný. S nejnovější verzí 8 je k dispozici také pod licencí AGPLv3.

    Ladislav Hagara | Komentářů: 1
    1.5. 19:22 | IT novinky

    Oficiální ceny Raspberry Pi Compute Modulů 4 klesly o 5 dolarů (4 GB varianty), respektive o 10 dolarů (8 GB varianty).

    Ladislav Hagara | Komentářů: 0
    30.4. 22:33 | Nová verze

    Byla vydána beta verze openSUSE Leap 16. Ve výchozím nastavení s novým instalátorem Agama.

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

    Devadesátková hra Brány Skeldalu prošla portací a je dostupná na platformě Steam. Vyšel i parádní blog autora o portaci na moderní systémy a platformy včetně Linuxu.

    karkar | Komentářů: 0
    30.4. 12:11 | Humor

    Lidi dělají divné věci. Například spouští Linux v Excelu. Využít je emulátor RISC-V mini-rv32ima sestavený jako knihovna DLL, která je volaná z makra VBA (Visual Basic for Applications).

    Ladislav Hagara | Komentářů: 7
    30.4. 10:44 | IT novinky

    Revolut nabídne neomezený mobilní tarif za 12,50 eur (312 Kč). Aktuálně startuje ve Velké Británii a Německu.

    Ladislav Hagara | Komentářů: 36
    Jaký filesystém primárně používáte?
     (58%)
     (1%)
     (9%)
     (21%)
     (4%)
     (1%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 503 hlasů
     Komentářů: 19, poslední 30.4. 11:32
    Rozcestník

    Relational pipes v0.18

    Nově oznámená verze Relačních rour v0.18 přináší řadu změn – podporu mnoha nových formátů, protokolů a transformací (ASN.1, INI, MIME, YAML, JSON, CBOR, HTML, QR, X11, XPath, XMLTable…). Nová je i podpora datových typů v CSV.

    Umožňují pracovat jednotným způsobem s řadou formátů (ASN.1, INI, MIME, YAML, JSON, CBOR, HTML, XML) a vytěžit z nich informace podobným způsobem jako to dělá databázová funkce XMLTable s daty ve formátu XML. Můžeme tak vytáhnout zajímavé informace např. z X.509 certifikátů, e-mailových zpráv nebo (i nevalidních) webových stránek.

    Můžeme se napojit na systém X11 a vypsat si otevřená okna, obrazovky či vstupní zařízení nebo zachytávat i generovat události (pohyby myši, stisky kláves).

    Z obrázků můžeme načítat čárové a QR kódy a to včetně souřadnic kódu (na obrázku jich může být víc).

    Filtry pro čtení a zápis CSV nově podporují datové typy (text, číslo, boolean) a to jak explicitně uložené v CSV, tak jejich autodetekci.

    Filtry pro pro práci s INI soubory podporují řadu dialektů (formát INI není standardizovaný) včetně klasických unixových konfiguračních souborů typu klíč=hodnota nebo javovských .properties a MANIFEST.MF souborů.

    Relational pipes jsou datový formát pro popis relačních dat + související nástroje, které slouží jako vstupní či výstupní filtry nebo transformace. Myšlenkově navazují na klasické unixové roury (skládání příkazů, každý program dělá jednu věc) a relační databáze.

    21.2.2022 08:00 | xkucf03 | Nová verze


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

    Komentáře

    Vložit další komentář

    21.2.2022 09:34 Mayhem
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    Musim rici, ze tento projekt sleduji dlouhodobe a vypada to skvele. Zajimalo by mne vsak, pouziva to nekdo nekde? Nebo je to one-man-show plnici ucel autora(coz je take naprosto ok)?
    21.2.2022 16:26 Ovr
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    Pro přímé předávání dat bez ukládání do soboru to vypadá zajímavě, docela mne to kdysi namlsalo. Ale nemají zveřejněnou plnou aktuální specifikaci a GPLv3 pro základní knihovnu taky není zrovna nejkompatibilnější volba. Navíc pro skriptování to není zas taková výhra, třeba jak to funguje v powershellu mi přijde šikovnější. Ale to je zas jiná písnička. Takže moje prográmky (víceméně osobní nebo drobné pracovní "skripty") zatím jedou jen obecný výstup do souboru nebo stdout. Je to nejjednodušší a stačí to.
    21.2.2022 11:19 Petr
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    Verze 0.18?! Přečtu si, co to vůbec je, až bude verze přinejmenším 10.0
    21.2.2022 11:21 Morapet
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    Mozna by to slo pouzit na analyzu dat z pro debugovani a maintenance/analyzu problemu s ETL, ku prikladu system sprcovava nejake data a spracovani vstupu selze, je potreba se podivat do dat neco opravit a znova spracovat. Spis tedy oprava dat nez jejiho formatu.
    21.2.2022 12:49 dyslektik
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    tldr; tohle není zprávička ale normální zpráva myslete i na ty kteří mají problém přečíst dlouhé texty, nebo snad nejste inkluzivní?
    22.2.2022 11:10 _
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    web pro mentalne postizene je jinde
    21.2.2022 12:56 Gréta
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    ta euforická kalkulačka :-D :-D :-D
    k3dAR avatar 22.2.2022 18:15 k3dAR | skóre: 63
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    @xkucf03 moc sem to nezkoukal, jen kouknulna par example, ale neni mi jasno... lze to pouzit na naplneni poli promenych z xml?
    <polozky>
        <polozka>
            <jmeno>prvni</jmeno>
            <barva>cervena</barva>
        </polozka>
        <polozka>
            <jmeno>druha</jmeno>
            <barva>zelena</barva>
        </polozka>
        <polozka>
            <jmeno>treti</jmeno>
            <barva>modra</barva>
        </polozka>
    </polozky>
    naplnit pole:
    jmeno[0]=prvni
    jmeno[1]=druha
    jmeno[2]=treti
    barva[0]=cervena
    barva[1]=zelena
    barva[2]=modra
    
    aktualne to delam pres spocitani polozek a pak rozdelit/parsovat v poctu cyklu pres grep,tac,cat,sed...
    porad nemam telo, ale uz mam hlavu... nobody
    xkucf03 avatar 22.2.2022 19:16 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Relational pipes v0.18

    To by použít šlo. Pro zajímavost přikládám Makefile pro stažení toho XML z tvého komentáře:

    all: položky.xml
    
    .PHONY: clean
    
    clean:
    	rm -f diskuse.html
    	rm -f položky.xml
    
    diskuse.html:
    	wget -O $@ --xattr https://www.abclinuxu.cz/zpravicky/relational-pipes-v0.18/diskuse#8
    
    položky.xml: diskuse.html
    	cat $(<) \
    		| relpipe-in-htmltable \
    			--relation 'pre' \
    				--records '//pre[1]' \
    				--attribute 'pre' string '.' \
    		| relpipe-out-nullbyte | tr \\0 \\n \
    		> $@

    To z HTML stránky extrahuje obsah prvního <pre/> elementu:

    <polozky>
        <polozka>
            <jmeno>prvni</jmeno>
            <barva>cervena</barva>
        </polozka>
        <polozka>
            <jmeno>druha</jmeno>
            <barva>zelena</barva>
        </polozka>
        <polozka>
            <jmeno>treti</jmeno>
            <barva>modra</barva>
        </polozka>
    </polozky>
    

    A potom to načtení XML a naplnění do proměnných:

    #!/bin/bash
    
    make položky.xml
    
    read_nullbyte() { local IFS=; for v in "$@"; do export "$v"; read -r -d '' "$v"; done }
    
    jmeno=();
    barva=();
    
    while read_nullbyte jmeno barva; do
    	jmeno+=("$jmeno");
    	barva+=("$barva");
    done < <(cat položky.xml \
    			| relpipe-in-xmltable \
    				--relation 'položka' \
    					--records '/polozky/polozka' \
    					--attribute 'jméno' string 'jmeno' \
    					--attribute 'barva' string 'barva' \
    			| relpipe-out-nullbyte)
    
    
    for j in ${jmeno[@]}; do echo "jméno: $j"; done
    for b in ${barva[@]}; do echo "barva: $b"; done

    Případně bez proměnných a rovnou nad každou položkou volat nějaký kód:

    #!/bin/bash
    
    make položky.xml
    
    read_nullbyte() { local IFS=; for v in "$@"; do export "$v"; read -r -d '' "$v"; done }
    
    cat položky.xml \
    	| relpipe-in-xmltable \
    		--relation 'položka' \
    			--records '/polozky/polozka' \
    			--attribute 'jméno' string 'jmeno' \
    			--attribute 'barva' string 'barva' \
    	| relpipe-out-nullbyte \
    	| while read_nullbyte j b; do
    		echo "jméno: $j";
    		echo "barva: $b";
    	done

    Vypíše to:

    make: „položky.xml“ je aktuální.
    jméno: prvni
    jméno: druha
    jméno: treti
    barva: cervena
    barva: zelena
    barva: modra

    P.S. k té funkci read_nullbyte(): ptal jsem se v konferenci Bashe, jestli by to šlo nějak lépe: Help-bash] Readig multiple null-separated values, ale asi nešlo. Přišlo by mi užitečné, kdyby to byla součást shellu resp. jeho funkce read.

    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
    k3dAR avatar 24.2.2022 22:49 k3dAR | skóre: 63
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    diky za komplexni priklad-reseni, vyzkousel sem a funguje :-) slo by zaroven vytahnout i info z vnorene podvetve? zkousel sem pridat dalsi sekci --records i dalsi --relation ale nedarilo se, pri --help na me rve ze ne, a ze zdrojaku sem se nezorientoval :)
    <polozky>
        <polozka>
            <jmeno>prvni</jmeno>
            <barva>cervena</barva>
            <jmeno>prvni</jmeno>
            <info>
                <vyska>100</vyska>
                <sirka>50</sirka>
            </info>
        </polozka>
        <polozka>
            <jmeno>druha</jmeno>
            <barva>zelena</barva>
            <info>
                <vyska>200</vyska>
                <sirka>60</sirka>
            </info>
        </polozka>
        <polozka>
            <jmeno>treti</jmeno>
            <barva>modra</barva>
            <info>
                <vyska>300</vyska>
                <sirka>70</sirka>
            </info>
        </polozka>
    </polozky>
    naplnit pole:
    jmeno[0]=prvni
    jmeno[1]=druha
    jmeno[2]=treti
    barva[0]=cervena
    barva[1]=zelena
    barva[2]=modra
    vyska[0]=100
    vyska[1]=200
    vyska[2]=300
    sirka[0]=50
    sirka[1]=60
    sirka[2]=70
    
    porad nemam telo, ale uz mam hlavu... nobody
    xkucf03 avatar 25.2.2022 00:30 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Relational pipes v0.18

    Pořádnou dokumentaci teprve píšu, zatím jsou jen ty příklady a bash-completion skripty.

    Do toho --attribute se píše název (jak se to má jmenovat na výstupu), typ a XPath výraz – ve kterém se dá jednoduše odkázat na vnořený element (dá se toho tam dělat i mnohem víc, volat různé funkce atd.). Takže v tomhle případě by to bylo jen info/vyska a info/sirka:

    while read_nullbyte jmeno barva vyska sirka; do
    	jmeno+=("$jmeno");
    	barva+=("$barva");
    	vyska+=("$vyska");
    	sirka+=("$sirka");
    done < <(cat položky.xml \
    			| relpipe-in-xmltable \
    				--relation 'položka' \
    					--records '/polozky/polozka' \
    					--attribute 'jméno' string 'jmeno' \
    					--attribute 'barva' string 'barva' \
    					--attribute 'výška' string 'info/vyska' \
    					--attribute 'šířka' string 'info/sirka' \
    			| relpipe-out-nullbyte)
    
    
    for j in ${jmeno[@]}; do echo "jméno: $j"; done
    for b in ${barva[@]}; do echo "barva: $b"; done
    for v in ${vyska[@]}; do echo "výška: $v"; done
    for s in ${sirka[@]}; do echo "šířka: $s"; done

    vypíše to:

    jméno: prvni
    jméno: druha
    jméno: treti
    barva: cervena
    barva: zelena
    barva: modra
    výška: 100
    výška: 200
    výška: 300
    šířka: 50
    šířka: 60
    šířka: 70

    Taky se někdy může hodit převést stromovou strukturu na plochou.

    #!/bin/bash
    
    soubor="položky.xml"
    
    make "$soubor"
    
    xml() { cat "$soubor"; }
    
    # xml() { cat ../yamltable/netplan.yaml | yaml2xml;  }
    
    plocha() {
    	relpipe-in-xmltable \
    		--relation 'data' \
    			--records '//text()[normalize-space() != ""]' \
    			--attribute 'key' string '..' --mode xpath \
    			--attribute 'value' string '.'
    }
    
    tecky() {
    	relpipe-tr-sed \
    		--relation '.+' \
    			--attribute 'key' \
    				--value '[/\[\]]+' \
    				--replacement '.' \
    			--attribute 'key' \
    				--value '^\.[^\.]+\.' \
    				--replacement ''
    }
    
    properties() {
    	relpipe-out-ini \
    		--relation '.*' \
    			--writer-option dialect java-properties \
    			--writer-option key-value-separator ' = '
    }
    
    xml | plocha | relpipe-out-tabular
    xml | plocha | tecky | properties
    

    Výstup:

    data:
     ╭────────────────────────────────┬────────────────╮
     │ key                   (string) │ value (string) │
     ├────────────────────────────────┼────────────────┤
     │ /polozky/polozka[1]/jmeno      │ prvni          │
     │ /polozky/polozka[1]/barva      │ cervena        │
     │ /polozky/polozka[1]/info/vyska │ 100            │
     │ /polozky/polozka[1]/info/sirka │ 50             │
     │ /polozky/polozka[2]/jmeno      │ druha          │
     │ /polozky/polozka[2]/barva      │ zelena         │
     │ /polozky/polozka[2]/info/vyska │ 200            │
     │ /polozky/polozka[2]/info/sirka │ 60             │
     │ /polozky/polozka[3]/jmeno      │ treti          │
     │ /polozky/polozka[3]/barva      │ modra          │
     │ /polozky/polozka[3]/info/vyska │ 300            │
     │ /polozky/polozka[3]/info/sirka │ 70             │
     ╰────────────────────────────────┴────────────────╯
    Record count: 12
    polozka.1.jmeno = prvni
    polozka.1.barva = cervena
    polozka.1.info.vyska = 100
    polozka.1.info.sirka = 50
    polozka.2.jmeno = druha
    polozka.2.barva = zelena
    polozka.2.info.vyska = 200
    polozka.2.info.sirka = 60
    polozka.3.jmeno = treti
    polozka.3.barva = modra
    polozka.3.info.vyska = 300
    polozka.3.info.sirka = 70

    Případně pro ten netplan.yaml:

    data:
     ╭────────────────────────────────────────────────────┬──────────────────╮
     │ key                                       (string) │ value   (string) │
     ├────────────────────────────────────────────────────┼──────────────────┤
     │ /yaml/network/version                              │ 2                │
     │ /yaml/network/ethernets/enp84s0/dhcp4              │ false            │
     │ /yaml/network/ethernets/enp84s0/dhcp6              │ false            │
     │ /yaml/network/ethernets/enp84s0/accept-ra          │ false            │
     │ /yaml/network/bridges/br0/interfaces[1]            │ enp84s0          │
     │ /yaml/network/bridges/br0/interfaces[2]            │ eth0             │
     │ /yaml/network/bridges/br0/addresses                │ 192.168.1.101/24 │
     │ /yaml/network/bridges/br0/gateway4                 │ 192.168.1.1      │
     │ /yaml/network/bridges/br0/nameservers/addresses[1] │ 192.168.1.10     │
     │ /yaml/network/bridges/br0/nameservers/addresses[2] │ 192.168.1.11     │
     │ /yaml/network/bridges/br0/mtu                      │ 1500             │
     │ /yaml/network/bridges/br0/parameters/stp           │ true             │
     │ /yaml/network/bridges/br0/parameters/forward-delay │ 4                │
     │ /yaml/network/bridges/br0/dhcp4                    │ false            │
     │ /yaml/network/bridges/br0/dhcp6                    │ false            │
     │ /yaml/network/bridges/br0/accept-ra                │ false            │
     ╰────────────────────────────────────────────────────┴──────────────────╯
    Record count: 16
    network.version = 2
    network.ethernets.enp84s0.dhcp4 = false
    network.ethernets.enp84s0.dhcp6 = false
    network.ethernets.enp84s0.accept-ra = false
    network.bridges.br0.interfaces.1. = enp84s0
    network.bridges.br0.interfaces.2. = eth0
    network.bridges.br0.addresses = 192.168.1.101/24
    network.bridges.br0.gateway4 = 192.168.1.1
    network.bridges.br0.nameservers.addresses.1. = 192.168.1.10
    network.bridges.br0.nameservers.addresses.2. = 192.168.1.11
    network.bridges.br0.mtu = 1500
    network.bridges.br0.parameters.stp = true
    network.bridges.br0.parameters.forward-delay = 4
    network.bridges.br0.dhcp4 = false
    network.bridges.br0.dhcp6 = false
    network.bridges.br0.accept-ra = false

    Na té stránce netplan.yaml je i ukázané, jak se dá vygenerovat víc relací z jednoho XML (--relation tam může být víckrát, --records je tam u každé jen jednou).

    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
    12.3.2022 09:05 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    aktualne to delam pres spocitani polozek a pak rozdelit/parsovat v poctu cyklu pres grep,tac,cat,sed...
    To by snad mělo jít udělat přes nějaký 'standardní' XML tooling ne?
    12.3.2022 09:26 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    Jo tak jsem to dohledal:

    #!/bin/bash
    
    IFS=$'\n'
    jmeno=( $(xmllint --xpath 'polozky/polozka/jmeno/text()' xml.xml) )
    barva=( $(xmllint --xpath 'polozky/polozka/barva/text()' xml.xml) )
    
    echo ${jmeno[@]}
    echo ${barva[@]}
    
    26.2.2022 13:20 upozorneni
    Rozbalit Rozbalit vše Re: Relational pipes v0.18
    UPOZORNÉNÍ --- Autor tohoto softwaru je ruský kolaborant, podobruje šíření ruských desinformací ve válce o Ukrajinu.

    Založit nové vláknoNahoru


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