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 16:55 | Nová verze

    Byla vydána verze 1.93.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 14:00 | Komunita

    Svobodný operační systém ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, slaví 30. narozeniny.

    Ladislav Hagara | Komentářů: 4
    dnes 11:00 | IT novinky

    Společnost Raspberry Pi má nově v nabídce flash disky Raspberry Pi Flash Drive: 128 GB za 30 dolarů a 256 GB za 55 dolarů.

    Ladislav Hagara | Komentářů: 2
    dnes 10:22 | Zajímavý software

    Technologie Skip pro multiplatformní mobilní vývoj, která umožňuje vývojářům vytvářet iOS a Android aplikace z jediné Swift a SwiftUI kódové základny, se s vydáním verze 1.7 stala open source.

    Ladislav Hagara | Komentářů: 3
    dnes 03:33 | Zajímavý software Ladislav Hagara | Komentářů: 1
    dnes 00:11 | Nová verze

    Byla vydána nová major verze 34.0.0 webového prohlížeče Pale Moon (Wikipedie) vycházejícího z Firefoxu. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 16:11 | Humor

    Win8DE je desktopové prostředí pro Wayland, inspirované nechvalně proslulým uživatelským rozhraním Metro z Windows 8. Nabízí dlaždicové rozhraní s velkými tlačítky a jednoduchou navigací, optimalizované pro dotyková zařízení. Cílem projektu je přetvořit design operačního systému Windows 8 do funkčního a minimalistického rozhraní vhodného pro každodenní použití na Linuxu.

    NUKE GAZA! 🎆 | Komentářů: 11
    včera 14:33 | Nová verze

    Laboratoře CZ.NIC vydaly Datovku 4.28.0 a Mobilní Datovku 2.6.0. Hlavní novinkou je ukládání rozpracovaných datových zpráv do konceptů. Datovka je svobodné multiplatformní aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi.

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

    Unix Pipe Game je vzdělávací karetní hra zaměřená na děti a rodiče, která děti učí používat unixové příkazy prostřednictvím interaktivních úkolů. Klíčovým prvkem hry je využití symbolu | pro pipeline neboli 'rouru', který umožňuje propojit výstupy a vstupy jednotlivých unixových příkazů, v tomto případě vytištěných na kartičkách. Předpokládá se, že rodič má alespoň nějaké povědomí o unixových příkazech a jejich provazování pomocí |.

    … více »
    NUKE GAZA! 🎆 | Komentářů: 3
    včera 13:55 | Zajímavý software

    PCIem je linuxový framework, který vytváří virtuální zařízení PCIe pomocí technik, které umožňují hostitelskému operačnímu systému rozpoznat tyto syntetické 'neexistující' karty jako fyzické zařízení přítomné na sběrnici. Framework PCIem je primárně zamýšlen jako pomůcka pro vývoj a testování ovladačů bez nutnosti použít skutečný hardware. Dle tvrzení projektu si fungování PCIem můžeme představit jako MITM (Man-in-the-Middle), který se nachází mezi ovladači a kernelem.

    NUKE GAZA! 🎆 | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (17%)
     (5%)
     (0%)
     (10%)
     (21%)
     (3%)
     (5%)
     (2%)
     (11%)
     (36%)
    Celkem 571 hlasů
     Komentářů: 17, poslední dnes 15:24
    Rozcestník

    Dotaz: python & sqlite: české řazení v "order by"?

    17.8.2007 12:10 vencas | skóre: 32
    python & sqlite: české řazení v "order by"?
    Přečteno: 2040×
    Chci aby mi select v sqlite vrátil položky setříděné podle příjmení, např.
    select firstname, lastname from students where grp='7a' order by lastname
    . Ovšem i přes nastavené locale (LC_ALL,LC_COLLATE oboje cs_CZ.UTF-8) se výsledek setřídí špatně, patrně podle unicode pozic: všecha akcentovaná písmena jsou na konci.

    Nevím, jestli je to problém v sqlite nebo v pythonu, řekl bych že v prvním. Sice si můžu výsledek dodatečně přerovnat v nějakém poli přes
    pole.sort(lambda a,b: locale.strcoll(a,b))
    nebo
    pole.sort(key=locale.strxfrm)
    , ale to jaksi není ono.

    Ví někdo jak na to? Dík moc!

    Odpovědi

    17.8.2007 12:28 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: python & sqlite: české řazení v "order by"?
    Podívejte se na část 7 v dokumentaci. Asi bude nutné najít nebo napsat příslušnou funkci pro porovnání.
    17.8.2007 12:33 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: python & sqlite: české řazení v "order by"?
    Aha, tak už jsem na to snad přišel...
    import locale
    locale.setlocale(locale.LC_ALL, '') ## LC_ALL=cs_CZ.UTF-8
    [...] 
    con.create_collation("lexical", locale.strcoll)
    con.execute("select firstname,lastname from students where grp='7a' order by lastname collate lexical")
    
    , případně vytváření tabulky uvést ke příslušným textovým sloupcům "COLLATE lexical". V každém skriptu je však třeba lexical znovu nadefinovat pomocí create_collation, neboť v databázi je uloženo jen její jméno.

    Omlouvám se za triviální dotaz i možná triviální odpověď, poprvé v životě si hraju s databází (asi ne naposled; je to mnohem lepší než mít všechno v asociativních polích a inkludovaných skriptech jako dosud ;-) )
    25.8.2008 09:34 JeCh
    Rozbalit Rozbalit vše Re: python & sqlite: české řazení v "order by"?
    Ahoj,

    mám stejný problém s řazením. Použil jsem Tvůj způsob, ale nefunguje mi to.Například Š se řadí mezi K a L. Přitom funkce locale.strcoll() vrací vše správně.

    Kde by mohl být problém? Díky.
    25.8.2008 11:51 JeCh
    Rozbalit Rozbalit vše Re: python & sqlite: české řazení v "order by"?
    Tak nic, už jsem na to přišel. Windows neumí nic jinýho než cp1250, takže je před řazením nutný to převést.

    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.