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 15:11 | Komunita

    Na webu konference Den IPv6, která se konala 4. června v Národní technické knihovně v pražských Dejvicích, jsou nyní k dispozici všechny prezentace (v PDF) a jejich videozáznamy. Organizátory konference byly i letos sdružení CESNET, CZ.NIC a NIX.CZ.

    VSladek | Komentářů: 0
    dnes 13:11 | Nová verze

    Byla vydána nová verze 9.1.0 správce sbírky fotografií digiKam (Wikipedie). Přehled novinek i s náhledy v oficiálním oznámení (NEWS). Vypíchnout lze vylepšené vyhledávání nebo podporu Pixel Motion Photos. Nejnovější digiKam je ke stažení také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo ke spuštění a spustit.

    Ladislav Hagara | Komentářů: 0
    dnes 11:44 | Pozvánky

    Přihlaste svou přednášku na další ročník konference LinuxDays, který proběhne 3. a 4. října na FIT ČVUT v pražských Dejvicích. Příjem témat poběží do konce prázdnin, pak proběhne veřejné hlasování a následně sestavení programu.

    Petr Krčmář | Komentářů: 2
    dnes 04:44 | Nová verze

    Byla vydána nová verze 2.4.68 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 13 zranitelností.

    Ladislav Hagara | Komentářů: 2
    včera 22:44 | IT novinky

    Apple na své vývojářské konferenci WWDC26 (Worldwide Developers Conference, keynote) představil řadu novinek. Vypíchnout lze novou generaci Apple Intelligence a zbrusu novou Siri, která dostala název Siri AI. Kvůli Aktu o digitálních trzích (DMA) však funkce Siri AI nebudou v systémech iOS 27 a iPadOS 27 k dispozici uživatelům v Evropské unii.

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

    Byla vydána nová verze 1.18.0 distribučního frameworku Flatpak (Wikipedie), tj. technologie umožňující distribuovat aplikace v podobě jednoho instalačního souboru na různé linuxové distribuce a jejich různá vydání. Přehled novinek na GitHubu. Vypíchnout lze podporu rozhraní /dev/kfd pro výpočty na kartách AMD (AMDKFD).

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

    aMule (Wikipedie), tj. multiplatformní klient pro peer-to-peer sdílení souborů pro sítě eD2k and Kademlia, byl po více než pěti letech od vydání poslední verze 2.3.3, vydán v nové major verzi 3.0.0 (GitHub). S novou webovou stránkou a dokumentací.

    Ladislav Hagara | Komentářů: 5
    včera 12:55 | IT novinky

    Byly vyhlášeni vítězové a zveřejněny vítězné zdrojové kódy (YouTube, GitHub) již 29. ročníku soutěže International Obfuscated C Code Contest (IOCCC), tj. soutěže o nejnepřehlednější (nejobfuskovanější) zdrojový kód v jazyce C.

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

    Evropská komise předložila evropský balíček pro technologickou suverenitu, tedy soubor opatření, která mají posílit kapacity EU v oblasti polovodičů, umělé inteligence, cloudu a open source. To Evropě pomůže stát se lídrem v oblasti umělé inteligence, posílit její digitální autonomii a vytvářet podmínky pro udržitelnější digitální budoucnost.

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

    OpenCV (Open Source Computer Vision, Wikipedie), tj. open source multiplatformní knihovna pro zpracování obrazu a počítačové vidění, byla vydána v nové major verzi 5.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1856 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: České třídění v perlu

    18.10.2012 19:23 Tomáš
    České třídění v perlu
    Přečteno: 673×
    Nevím jak donutit perl, aby třídil správně česky, jakmile přepnu LC_COLLATE zařadí se řetězce s mezerou chybně na konec:
    use POSIX qw /locale_h/;
    use locale;
    
    @a = ('A š', 'A v', 'Aaa');
    
    setlocale LC_COLLATE, "C";
    print "$_\n" foreach sort @a;
    
    print "\n";
    setlocale LC_COLLATE, "cs_CZ.UTF-8";
    print "$_\n" foreach sort @a;
    
    A v
    A š
    Aaa
    
    Aaa
    A š
    A v
    

    Odpovědi

    18.10.2012 20:52 myšák | skóre: 26 | blog: EmentuX | Ostrava
    Rozbalit Rozbalit vše Re: České třídění v perlu

    No jestli on nebude problém spíš v tom, že sort v Perlu spoléhá na to, co mu "vrátí systémový sort". Viz následující:

    mike@tinky:~$ locale
    LANG=cs_CZ.UTF-8
    LANGUAGE=
    LC_CTYPE="cs_CZ.UTF-8"
    LC_NUMERIC="cs_CZ.UTF-8"
    LC_TIME="cs_CZ.UTF-8"
    LC_COLLATE="cs_CZ.UTF-8"
    LC_MONETARY="cs_CZ.UTF-8"
    LC_MESSAGES="cs_CZ.UTF-8"
    LC_PAPER="cs_CZ.UTF-8"
    LC_NAME="cs_CZ.UTF-8"
    LC_ADDRESS="cs_CZ.UTF-8"
    LC_TELEPHONE="cs_CZ.UTF-8"
    LC_MEASUREMENT="cs_CZ.UTF-8"
    LC_IDENTIFICATION="cs_CZ.UTF-8"
    LC_ALL=
    mike@tinky:~$ cat ./foo 
    A š
    A v
    Aaa
    mike@tinky:~$ sort ./foo 
    Aaa
    A š
    A v
    

    Možná bych popřemýšlel o použití Cz::Sort

    Je nesmírně těžké být idiotem, konkurence je obrovská...
    18.10.2012 21:58 tom
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Ono to je nejspis podle normy dobre, protoze ta pred abecedu radi jen tvrdou mezeru.
    18.10.2012 22:11 myšák | skóre: 26 | blog: EmentuX | Ostrava
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Jak je to přesně podle normy netuším :-( Na to by musel odpovědět nějaký znalec, za kterého se rozhodně nepovažuji...
    Je nesmírně těžké být idiotem, konkurence je obrovská...
    18.10.2012 22:51 tom
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Ve vycucu z ČSN 97 6030 se pise
    Spojovník a nepřerušující mezera před abecedou.
    vizte http://racek.vlada.cz/usneseni/usneseni_webtest.nsf/WebGovRes/0AD8FEF4CC04B7A4C12571B6006D69D0?OpenDocument
    19.10.2012 12:45 myšák | skóre: 26 | blog: EmentuX | Ostrava
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Díky za odkaz - člověk se pořád učí. Nicméně bych si v tomto případě dovolil postesknout nad jistou nelogičností, kterou v tomto pravidle vidím. Ačkoliv chápu, že v češtině máme podobných úchvatných „mozkolamů“ přehršel, tak konkrétně v tomto případě je to opravdu na mašli. Pokud odhlédneme od typografie, kde rozdíl mezi spojovníkem, nezalomitelnou mezerou a obyčejnou mezerou dává smysl, tak při řazení slov smysl poněkud postrádám. Ale jak jsem psal v předchozím příspěvku, necítím se být odborníkem na všechny kličky mého rodného jazyka a jsem rád, že intuitivně ovládám alespoň jeho základy.
    Je nesmírně těžké být idiotem, konkurence je obrovská...
    19.10.2012 12:47 l4m4
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Tady ale nejde o řazení slov, slova mezery neobsahují žádné. Jde o řazení frází.
    18.10.2012 20:55 Mirek
    Rozbalit Rozbalit vše Re: České třídění v perlu
    18.10.2012 21:42 myšák | skóre: 26 | blog: EmentuX | Ostrava
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Proměnnou LANG může mít nastavenou jak chce, protože v tom skriptu si nastavuje dle potřeby LC_COLLATE na cs_CZ.utf8 ;-)
    Je nesmírně těžké být idiotem, konkurence je obrovská...
    18.10.2012 22:08 myšák | skóre: 26 | blog: EmentuX | Ostrava
    Rozbalit Rozbalit vše Re: České třídění v perlu

    Problém je v tom, že v definici locale je pro znak "mezera" (nejen) v cs_CZ.utf8 krpa, která znepříjemňuje život nejen v Perlu, ale tak nějak napříč systémem. :-( Existuje pro to dokonce zdokumentovaná oprava:

    1. V souboru /usr/share/i18n/locales/cs_CZ je třeba opravit řádek:
      <U0020> IGNORE;IGNORE;IGNORE;<U0020> na <U0020> <U0020>;IGNORE;<U0020>;<U0020>
    2. Vypsat z archivu všechny české definice:
      $ localedef --list-archive | grep cs_CZ
      cs_CZ
      cs_CZ.utf8
      
      a smazat je:
      localedef --delete-from-archive cs_CZ
      localedef --delete-from-archive cs_CZ.utf8
      
    3. Vytvořit novou binární podobu z opravené textové definice:
      localedef -i /usr/share/i18n/locales/cs_CZ -f UTF-8 /usr/lib/locale/cs_CZ
      localedef -i /usr/share/i18n/locales/cs_CZ -f UTF-8 /usr/lib/locale/cs_CZ.UTF-8
      
    4. V adresáři s archivem přidat binárky do archivu:
      cd /usr/lib/locale/
      localedef --add-to-archive cs_CZ
      localedef --add-to-archive cs_CZ.UTF-8
      
    5. Na konci pro jistotu zkontrolovat, že je vše OK:
      $ localedef --list-archive | grep cs_CZ
      cs_CZ
      cs_CZ.utf8
      

    A voilá po opravě locale:

    $ cat foo 
    A v
    Abc
    A b
    A š
    A č
    Aaa
    
    $ sort foo 
    A b
    A č
    A š
    A v
    Aaa
    Abc
    
    

    Je nesmírně těžké být idiotem, konkurence je obrovská...
    19.10.2012 10:45 Tomáš
    Rozbalit Rozbalit vše Re: České třídění v perlu

    Díky moc

    A musim říct, že v glibc jsem chybu opravdu nečekal, nemělo by se to někam bugreportovat? Nebo existuje nějaký důvod proč je to takhle?

    19.10.2012 12:01 tom
    Rozbalit Rozbalit vše Re: České třídění v perlu
    Nebo existuje nějaký důvod proč je to takhle?
    http://www.abclinuxu.cz/poradna/programovani/show/367555#7

    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.