abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 10:44 | Zajímavý článek

    Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.

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

    Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.90 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.90 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

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

    Byla vydána (Mastodon, 𝕏) nová verze 2024.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | IT novinky

    Počítačová hra Tetris slaví 40 let. Alexej Pažitnov dokončil první hratelnou verzi 6. června 1984. Mezitím vznikla celá řada variant. Například Peklo nebo Nebe. Loni měl premiéru film Tetris.

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

    MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.23.0. V přehledu novinek je vypíchnuta podpora dynamických USB zařízení nebo nové moduly openamp, tls a vfs.

    Ladislav Hagara | Komentářů: 0
    včera 10:22 | Nová verze

    Canonical vydal Ubuntu Core 24. Představení na YouTube. Nová verze Ubuntu Core vychází z Ubuntu 24.04 LTS a podporována bude 12 let. Ubuntu Core je určeno pro IoT (internet věcí) a vestavěné systémy.

    Ladislav Hagara | Komentářů: 2
    včera 01:00 | Nová verze Ladislav Hagara | Komentářů: 0
    4.6. 19:55 | IT novinky

    Intel na veletrhu Computex 2024 představil (YouTube) mimo jiné procesory Lunar Lake a Xeon 6.

    Ladislav Hagara | Komentářů: 0
    4.6. 13:44 | IT novinky

    Na blogu Raspberry Pi byl představen Raspberry Pi AI Kit určený vlastníkům Raspberry Pi 5, kteří na něm chtějí experimentovat se světem neuronových sítí, umělé inteligence a strojového učení. Jedná se o spolupráci se společností Hailo. Cena AI Kitu je 70 dolarů.

    Ladislav Hagara | Komentářů: 0
    4.6. 13:22 | Nová verze

    Byla vydána nová verze 14.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    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: 62
    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: 62
    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.