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

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 163 (pdf).

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

    Eric Lengyel dobrovolně uvolnil jako volné dílo svůj patentovaný algoritmus Slug. Algoritmus vykresluje text a vektorovou grafiku na GPU přímo z dat Bézierových křivek, aniž by využíval texturové mapy obsahující jakékoli předem vypočítané nebo uložené obrázky a počítá přesné pokrytí pro ostré a škálovatelné zobrazení písma, referenční ukázka implementace v HLSL shaderech je na GitHubu. Slug je volným dílem od 17. března letošního

    … více »
    NUKE GAZA! 🎆 | Komentářů: 1
    včera 15:11 | Zajímavý projekt

    Sashiko (GitHub) je open source automatizovaný systém pro revizi kódu linuxového jádra. Monitoruje veřejné mailing listy a hodnotí navrhované změny pomocí umělé inteligence. Výpočetní zdroje a LLM tokeny poskytuje Google.

    Ladislav Hagara | Komentářů: 12
    včera 04:44 | Zajímavý software

    Cambalache, tj. RAD (rapid application development) nástroj pro GTK 4 a GTK 3, dospěl po pěti letech vývoje do verze 1.0. Instalovat jej lze i z Flathubu.

    Ladislav Hagara | Komentářů: 0
    20.3. 14:55 | Nová verze

    KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    20.3. 13:22 | IT novinky

    Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.

    Ladislav Hagara | Komentářů: 16
    20.3. 04:44 | Zajímavý článek

    Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).

    Ladislav Hagara | Komentářů: 2
    20.3. 00:33 | Nová verze

    Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    20.3. 00:11 | Zajímavý software

    Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.

    Ladislav Hagara | Komentářů: 7
    19.3. 19:22 | Nová verze

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1131 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: jak dam vedle sebe v xslt dva ruzne dlouhe sloupce z ruznych zdroju, aby se kratsi dorovnal prazdnyma bunkama

    28.11.2013 07:52 jeleniste | skóre: 13 | blog: Prokustovo lože
    jak dam vedle sebe v xslt dva ruzne dlouhe sloupce z ruznych zdroju, aby se kratsi dorovnal prazdnyma bunkama
    Přečteno: 559×
    Mam dotaz Delam nejake vypisy z db do html. Z db generuju xml a ve vypisu potrebuju mit vedle sebe vypsane v jedne html tabulce dva ruzne dotazy do db, ktere obvykle vraci kazdy jiny pocet radku. Jak udělám v xslt, abych měl na konci dorovnanej ten kratší prázdnejma buňkama (nebo jednou s colspan="0"?
    Teď to řešim v sql, že to zjoinuju a už mi to tam ty prázdný buňky vrací, ale to neni moc čistý řešení, chtěl bych do db šahat jen pro data a strukturu řešit komplet v xslt (který žel bohu moc neumim, co nevygůgluju nemam). Dá se to nějak elegantně udělat? Díky Je;
    Nejsem blbý, jen se hloupě ptám

    Řešení dotazu:


    Odpovědi

    Řešení 1× (jeleniste (tazatel))
    28.11.2013 08:31 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: jak dam vedle sebe v xslt dva ruzne dlouhe sloupce z ruznych zdroju, aby se kratsi dorovnal prazdnyma bunkama
    Předpokládám, že vstup má +- takovouhle formu:
    <?xml version="1.0"?>
    <data>
     <a>
      <item>Alpha</item>
      <item>Bravo</item>
      <item>Charlie</item>
     </a>
     <b>
      <item>Zulu</item>
     </b>
    </data>
    Pak následující dorovná buňky pomlčkama.
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    
    <xsl:output method="html" indent="yes" />
    
    <xsl:template match="/">
        <html>
            <head><title>Title</title></head>
            <body>
                <xsl:apply-templates select="data" />
            </body>
        </html>
    </xsl:template>
    
    <xsl:template match="data">
    <xsl:variable name="THIS" select="." />
    <xsl:variable name="BOTH" select="a/item | b/item" />
    <table border="1">
        <xsl:for-each select="$BOTH[(position() &lt;= count($THIS/a/item)) or (position() &lt;= count($THIS/b/item))]">
            <xsl:variable name="INDEX" select="position()" />
            <tr>
                <td>
                    <xsl:value-of select="$INDEX" />
                </td>
                <td>
                    <xsl:choose>
                        <xsl:when test="$INDEX &lt;= count($THIS/a/item)">
                            <xsl:apply-templates select="$THIS/a/item[$INDEX]" />
                        </xsl:when>
                        <xsl:otherwise>
                            -
                        </xsl:otherwise>
                    </xsl:choose>
                </td>
                <td>
                    <xsl:choose>
                        <xsl:when test="$INDEX &lt;= count($THIS/b/item)">
                            <xsl:apply-templates select="$THIS/b/item[$INDEX]" />
                        </xsl:when>
                        <xsl:otherwise>
                            -
                        </xsl:otherwise>
                    </xsl:choose>
                </td>
            </tr>
        </xsl:for-each>
    </table>
    </xsl:template>
    
    <xsl:template match="item">
        <b><xsl:value-of select="." /></b>
    </xsl:template>
    
    </xsl:stylesheet>

    Trik je v tom, že se vyberou oba dva uzly pro for-each iteraci a v každém průchodu se kontroluje, jestli tam takový prvek je.

    Ale nevím, jak to bude rychlé pro větší data.

    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    28.11.2013 09:11 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: jak dam vedle sebe v xslt dva ruzne dlouhe sloupce z ruznych zdroju, aby se kratsi dorovnal prazdnyma bunkama
    Supr, to je ono. Díky moc.
    Nejsem blbý, jen se hloupě ptám

    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.