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í
×
    26.12. 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    26.12. 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 7
    26.12. 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    26.12. 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    25.12. 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 30
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (35%)
     (1%)
     (20%)
     (1%)
     (1%)
     (1%)
     (12%)
     (12%)
     (15%)
    Celkem 161 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: Blbne čeština (utf8) v perlu a v C

    ⧠ A = 0 avatar 7.10.2007 18:26 ⧠ A = 0 | skóre: 11 | blog: Technokratovo_zrcadlo | Helsinki
    Blbne čeština (utf8) v perlu a v C
    Přečteno: 790×
    Zdravím. Mám debian s cs_CZ.utf8 a potřeboval bych nějakým způsobem přečíst jednotlivý znak (i český) a nějak ho zpracovat. Nejprve jsem si hrál v C, s pomocí wcharů, ale getwchar() mi začne vracet WEOF, jakmile narazí na český non-ascii znak.

    Pak jsem zkoušel něco napsat v perlu. A třeba na následující jednoduché utilitce na počítání četnosti znaků jsem si vylámal zuby:

    use locale;
    $_ = <STDIN>;
    %znaky = ();
    while ( /(\S)/) {
    if (exists($znaky{$&})) {
    $znaky{$&} += 1;
    }
    else {
    $znaky{$&} = 1;
    }
    $_ = $';
    }

    foreach $c (keys(%znaky))
    {
    print "$c $znaky{$c}\n"
    }

    Tady mi to pro změnu české non-ascii znaky půlí na nějaké dva nečitelné znaky. Např. pro vstup "ščdfs" dostanu tohle:

    � 1
    � 1
    d 1
    � 1
    s 1
    f 1
    � 1

    Naveďte mě, co dělám špatně, prosím.

    Nevolte zmrdy.

    Odpovědi

    7.10.2007 18:37 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    perl-u treba o utf8 povedať. Štandardne sa tvári, ako keby nič také neexistovalo.
    use utf8;
    
    binmode (STDIN, 'utf8');
    binmode (STDOUT, 'utf8');
    
    7.10.2007 23:27 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    use utf8; pouze říká, že od teď je zdroják v UTF-8.

    Co se týče binmode(STDIN, ':utf8'), tak záleží na verzi (a distribuci). Jsou takové, kde jedině binmode zajistí korektní I/O, jsou takové, kde to funguje podle locale, ale padají varování, a jsou takové, kde to funguje „samo od sebe“.
    8.10.2007 09:30 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    utf8 obsahuje zopár užitočných funkcií ..

    čo sa týka samotného perlu, ten, ak mu inak nik nepovie, utf8 nepozná. Povedať sa mu to (o STDIN/OUT/ERROR) dá napr. perl -C L (podľa locale), perl -IOEioA (natvrdo, aj @ARGV v utf8)

    7.10.2007 18:38 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    Ty dva nečitelné znaky je bajtová reprezentace těch českých znaků. Tj. Perl ten vstup zpracovává po bajtech – buď neumí UTF-8, nebo neví, že vstup je v UTF-8. Máte locale nastaveno na cs_CZ.UTF-8?
    ⧠ A = 0 avatar 7.10.2007 19:12 ⧠ A = 0 | skóre: 11 | blog: Technokratovo_zrcadlo | Helsinki
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    To je mi celkem jasné. Locale samozřejmě nastavené mám. Pomohlo to binmode. Ještě by mě zajímalo, jak je to s tím Cčkem.
    Nevolte zmrdy.
    8.10.2007 01:10 megi | skóre: 11 | blog:
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    Na C potrebujes nejakou knihovnu. Ja pouzivanm glib2, pze je vsude.

    http://library.gnome.org/devel/glib/stable/glib-Unicode-Manipulation.html
    ⧠ A = 0 avatar 11.10.2007 16:41 ⧠ A = 0 | skóre: 11 | blog: Technokratovo_zrcadlo | Helsinki
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    A to tedy podle Vás standardní C99 s wchary a locale vůbec neumí utf8?
    Nevolte zmrdy.
    8.10.2007 13:20 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    Pardon jestli jem mimo co se týče Perlu, ale v Pythonu je třeba explicitně říci, že má používat systémové locale voláním
    import locale; locale.setlocale(locale.LC_ALL, '')
    . Není to v Perlu podobně?
    8.10.2007 14:41 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Blbne čeština (utf8) v perlu a v C
    nie, pragma use locale to robí automaticky. setlocale je treba len vtedy, ak chce program iné

    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.