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í
×

včera 16:22 | Nová verze

Byla vydána verze 0.11.0 softwaru pro statistickou analýzu dat GNU PSPP (Wikipedie), svobodné alternativy k proprietárnímu softwaru IBM SPSS Statistics (Wikipedie). Vedle několika vylepšení a oprav chyb jsou řešeny také 2 bezpečnostní chyby CVE-2017-10791 a CVE-2017-10792. O týden později byla vydána verze 1.0.0 přinášející pouze aktualizaci překladů. Proč verze 1.0.0 a ne například 0.11.1? Dle vývojářů jsou důvody následující:

… více »
Ladislav Hagara | Komentářů: 0
včera 10:35 | Komunita

Na blogu Oracle se objevila zpráva o tom, že plánovaná verze Java EE 8 bude uvolněna jako open source (referenční implementace a compatibility kit). V současné době je uvolněna jen Java SE (standard edition) pod licencí GPLv2 v podobě OpenJDK (Open Java Development Kit), kterou začal v roce 2006 uvolňovat Sun.

Max | Komentářů: 3
21.8. 23:55 | IT novinky

Google na YouTube oficiálně představil Android 8.0 Oreo. Přehled novinek v příspěvku na blogu věnovaném vývojářům.

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

Po téměř 3 měsících od vydání třetího čísla publikoval Michal Špaček na svých stránkách čtvrté číslo newsletteru věnovanému bezpečnosti, bezpečnému vývoji převážně webových aplikací a bezpečnosti uživatelů. Jedná se současně o číslo poslední: "Nepíše se mi to lehce, a trvalo to, než jsem to ze sebe dostal, ale tohle je poslední newsletter v této podobě. Ani jsem ho nestihl pojmenovat a už jsem ho zabil. Nezbývá mi tolik času, abych každou událost, novinku a změnu v prohlížeči detailně popisoval tak, jak bych v newsletteru chtěl, mrzí mě to".

Ladislav Hagara | Komentářů: 2
21.8. 07:00 | Nová verze

Byla vydána diaspora* ve verzi 0.7.0.0. Jedná se o svobodný software, který slouží jako osobní webový server pro poskytování služeb sociální sítě (Wikipedie). Přehled novinek v příspěvku na blogu a na GitHubu. Sociální síť diaspora* byla před pěti lety předána komunitě.

Ladislav Hagara | Komentářů: 0
21.8. 06:00 | IT novinky

Společnost Hardkernel stojící za jednodeskovými počítači ODROID představila na YouTube minipočítač určený pro domácí cloud ODROID-HC1 vycházející z ODROID-XU4. Minipočítač s kovovou krabičkou, do které stačí vložit 2 a půl palcový disk, lze koupit za 49 dolarů. ODROID-HC1 je stohovatelný.

Ladislav Hagara | Komentářů: 39
20.8. 16:22 | Nová verze

Byl vydán DB Browser for SQLite (sqlitebrowser) ve verzi 3.10.0. Nejnovější stabilní verze této grafické nadstavby nad relačním databázovým systémem SQLite (Wikipedie) přináší například integraci s DBHub.io, tj. platformou pro sdílení SQLite databází. Podrobnosti na GitHubu.

Ladislav Hagara | Komentářů: 2
20.8. 08:00 | IT novinky

Andy Rubin, spoluzakladatel společnosti Android, jež byla v roce 2005 koupena Googlem, nyní CEO společnosti Essential Products, oznámil předprodej chytrého telefonu Essential. Telefon se začne rozesílat 1. září. Cena telefonu je 699 dolarů. Cena telefonu současně s 360° kamerou s rozlišením 4K byla stanovena na 749 dolarů. Kameru, v budoucnu i další příslušenství, lze k telefonu připojit pomocí konektoru s magnety.

Ladislav Hagara | Komentářů: 1
19.8. 13:44 | Zajímavý software

Evropská komise vydala novou verzi 1.4.0.1 svého open source v Javě naprogramovaného softwaru pro online průzkumy EUSurvey. Online dotazníky lze vytvářet na stránkách Evropské komise nebo si lze software stáhnout (zip a war) a nainstalovat lokálně. Zdrojové kódy jsou k dispozici pod licencí EUPL (European Union Public Licence).

Ladislav Hagara | Komentářů: 0
18.8. 23:55 | Komunita

Ubuntu 17.10 (Artful Aardvark) bude ve výchozím stavu zobrazovat Dok (Launcher). Jedná se o rozšíření GNOME Shellu Ubuntu Dock. To bylo forknuto z rozšíření Dash to Dock. Ukázka na YouTube [reddit].

Ladislav Hagara | Komentářů: 8
Těžíte nějakou kryptoměnu?
 (5%)
 (2%)
 (18%)
 (76%)
Celkem 374 hlasů
 Komentářů: 21, poslední 13.8. 09:57
    Rozcestník

    Dotaz: sort v perlu dle cest ..

    nettezzaumana avatar 27.5.2009 09:58 nettezzaumana | skóre: 3
    sort v perlu dle cest ..
    Přečteno: 351×
    ciao ..

    prosim poradte mi, nemuzu na to prijit .. jak se prosim v perlu sesortuje @foo jako cesty (paths), to znamena, ze je dodrzovan "directory-tree" dle "/", podobne jako ze shelloveho `find`.
    sort { $a =~ tr[/][] <=> $b =~ tr[/][] || $a cmp $b; } @flist
    tohle je docela blizko, ale stejne to udela nakonec spatne ..

    zde najdete .. ps. abych Vam usetril praci, tak kodem nize vytvorite @foo ::

    #!/usr/bin/env perl
    
    use warnings;
    use strict;
    use File::Find;
    
    sub build_flist {
            my($fpath);
            our(@flist);
            $fpath = shift;
    #       chdir("$fpath");
            @flist = "";
            find(\&wanted, "$fpath");
            sub wanted {
                    my($found);
                    $found = $File::Find::name;
                    push(@flist, "$found");
            };
    
    #        return sort {
    #                $a =~ tr[/][] <=> $b =~ tr[/][] || $a cmp $b;
    #                } @flist;
             return @flist;
    };
    
    my $action = $ARGV[0];
    
    print "$_\n" foreach(build_flist("$action"));
    
    exit;

    Odpovědi

    nettezzaumana avatar 27.5.2009 10:21 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    order by mel bejt ::
    $rootdir/$singlefiles .. ->
    $rootdir/$nextdir1/$singlefiles .. ->
    $rootdir/$nextdir2/$singlefiles ..
    btw. delam to proto, ze na ruznych operacnich systemech co pouzivam mi File::Find dela jinej defaultni order a ja ho potrebuju explicitne sesortovat ..
    27.5.2009 11:12 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Pokud chcete to co si myslím že chcete, tj. seřadit tak aby nejprv byly soubory a pak adresáře, tak by mohlo pomoci něco jako:
    sort { $a =~ tr[/][\xff]; $b =~ tr[/][\xff]; $a cmp $b; }
    To za předpokladu, že nebudete mít unicode, v opačném případě si tam dejte nějaký jiný znak, který je dostatečně "vzadu". Pokud by se v názvech souborů objevil ten znak \xff, tak můžete použít místo substituce rotaci:
    sort { $a =~ tr[/-\xff][0-\xff/]; $b =~ tr[/-\xff][0-\xff/]; $a cmp $b; }
    In Ada the typical infinite loop would normally be terminated by detonation.
    nettezzaumana avatar 27.5.2009 12:35 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    hehe. nechci byt ironicky ale zkousel jste kod co jste postnul?

    potrebuju aby byla zachovana stromova struktura aka
    root/file1
    root/file2
    root/dir1
    root/dir1/file1
    root/dir1/file1
    root/dir1/sdir1
    root/dir1/sdir1/file1 .. filex
    root/dir2
    root/dir2/file1 .. filex
    root/dir2/sdir .. blah
    
    ..
    root/dirx/sdirx.*/filex
    27.5.2009 12:42 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Zkoušel jsem ho do té míry že není syntakticky špatný, proto jsem napsal "něco jako". Nechci být ironický, ale děkuji za podrobné vysvětlení co ten kód dělá špatně a jak to má vypadat správně.
    In Ada the typical infinite loop would normally be terminated by detonation.
    nettezzaumana avatar 27.5.2009 13:01 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    nicmene napadla me jina cesta .. je to sice takovej "coding u-turn" ale snad by to mohlo jit ::

    uz pri vytvareni pole vybirat do @flist soubory (File::Find::name) a do @dlist adresare (File::Find::dir) a potom na zaklade *neceho (?mrzkeho) obe pole sloucit ..
    27.5.2009 15:12 kaaja | skóre: 23 | blog: Sem tam něco | Podbořany, Praha
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..

    Já vidím problém v tom, jak poznat rozdíl mezi root/file1 a root/dir1. Pokud by třeba dir měla na konci vždy /, tak by při tom porovnávání se dalo udělat něco jako

    sort{
    if (($a ~= /\/$/ ) && !($b ~= /\/$/)) { return 1; } 
    elseif ( !($a ~= /\/$/ ) && ($b ~= /\/$/)) {return -1;}
    else {return $a cmp $b; }
    }
    

    Kód jsem netestoval (nemám ho  teď kde pustit), takže to berte jenom jako námět.

     

    nettezzaumana avatar 27.5.2009 16:35 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    #!/usr/bin/env perl
    
    use warnings;
    use strict;
    use File::Find;
    
    sub build_flist {
            my($fpath);
            our(@flist, @dlist, @overall);
            $fpath = shift;
            @flist = "";
            @dlist = "";
            @overall = "";
            find(\&wanted, "$fpath");
    
            ## vytvorime dve pole, jedno obsahuje jen adresare (@dlist)
            ## a druhe soubory (@flist)
            sub wanted {
                    my $found = $File::Find::name;
                    push(@dlist, $found) if(-d "$found");
                    push(@flist, $found) if(-f "$found");
            };
    
            # kvulli pop()ovani je reverzne sortneme
            @dlist = sort @dlist;
            @flist = sort {$b cmp $a} @flist;
    
            ## zacneme vytvaret finalni pole @overall, do ktereho se snazime
            ## spojit obe pole s adresari a soubory,
            ## `for(1 .. @dlist)` pouzivame misto `foreach(@dlist)` abychom se
            ## pop()em nezrali od ocasu .. zaroven si prelejvame jedno pole do
            ## druheho, misto abychom duplikovanim zabirali prilis pameti ..
            for(1 .. @dlist) {
                    my $foo = pop(@dlist);
                    push(@overall, "$foo") if($foo ne $overall[@overall - 1]);
    
                    # a zde by mela prijit finalni finta:
                    # vytvorime cyklus ktery >> dokud bude stejnej posledni pop()nutej
                    # prvek do @overall ($foo) jako posledni prvek z pole se soubory
                    # oriznutej o jmeno souboru takze zbyde adresar ($flist[@flist - 1] =~ s@/.[^/]+$@@) <<
                    # tak ten posledni prvek z @flist push()ne do @overall a pop()neme z @flist..
    
            };
    
            return @dlist;
    };
    
    my $action = $ARGV[0];
    
    print "$_\n" foreach(build_flist("$action"));
    
    exit;
    
    27.5.2009 18:26 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Kdybyste se tak křečovitě nedržel File::Find tak by to šlo i jednodušeji.
    #!/usr/bin/perl
    
    require 5.010_000;
    use strict;
    use warnings;
    use feature qw/switch say/;
    use autodie qw/opendir readdir/;
    
    
    # fetch arguments...
    my @dirs = sort @ARGV;
    @dirs = qw/./ unless scalar @dirs;
    
    my @output;
    
    # walk through directory queue...
    while (my $dir = shift @dirs) {
    
            # include this directory in output...
            push @output, $dir;
    
            # temporary array for directory objects
            # we use this to maintain the already sorted order...
            my @localdirs;
            
            # process all entries in this directory...
            opendir(my $dh, $dir);
            for my $obj (sort readdir($dh)) {
                    # skip dot and dotdot...
                    next if $obj ~~ [qw/. ../];
    
                    # figure out the full path and process it...
                    given ("$dir/$obj") {
                            # files go to output...
                            when (-f) { push @output, $_ }
    
                            # dirs go to temp. array...
                            when (-d) { push @localdirs, $_ }
                    }
            }
    
            # prepend found directories to the queue...
            unshift @dirs, @localdirs if scalar @localdirs;
    }
    
    say join("\n", @output);
    
    Žádné tajné triky :)
    In Ada the typical infinite loop would normally be terminated by detonation.
    nettezzaumana avatar 28.5.2009 09:07 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Vas kod sam o sobe vyhodil nejake ohavne errory, jako chybejici autodie, ale po male uprave sel (bohuzel jen na Linuxu) .. protoze to potrebuju *klasickou metodou funkcni i na systemech jako solaris 8, tak sem musel sbustlit metodu nize:

    rad se necham poucit s opravou te fce, co slucuje obe pole, je to totiz neunosne pomale. experimentoval jsem s prerovnavanim a shiftovanim z obou poli, ale je to pomale stejne ..

    diky a zdravim
    #!/usr/bin/env perl
    
    use warnings;
    use strict;
    use File::Find;
    
    our(@files, @dirs);
    my($input, @final, $foo, $bar);
    
    find(\&bingo, shift(@ARGV));
    
    sub bingo {
            $_ = $File::Find::name;
            push(@files, $_) if -f;
            push(@dirs, $_) if -d;
    };
    
    @files = sort(@files);
    @dirs = sort(@dirs);
    
    #### playground:
    while($input = shift(@ARGV)) {
            if($input eq 'd') {
                    print "$_\n" foreach(@dirs);
                    next;
            };
            if($input eq 'f') {
                    print "$_\n" foreach(@files);
                    next;
            };
            if($input eq 'a') {
    
                    ## sorting is *very *very slow ..
                    foreach(@dirs) {
                            $foo = $_;
                            push(@final, $foo);
                            foreach(@files) {
                                    $bar = $_;
                                    $bar =~ s@/.[^/]*$@@;
                                    push(@final, $_) if($foo eq $bar);
                            };
                    };
                    print "$_\n" foreach(@final);
            };
    };
    
    exit;
    
    28.5.2009 09:46 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Je to neúnosně pomalé, protože to zavání kvadratickou nebo bůhvíjakou složitostí. Určitě by to šlo nějak zrychlit, ale pouze konstantní mírou, takže pro velký objem dat to stejně bude pasé.

    Ten Váš přístup je prostě no-go. Fundamentální problém je v tom, že kvůli File::Find házíte vše do jednoho pytle (resp. dvou pytlů) a tak ztrácíte možnost správně zařadit věci ve chvíli, kdy přijdou pod ruku. Pak se to snažíte krkolomně rozuzlit. Je to typický příklad nepředávání důležité informace mezi částmi programu.

    Můj program je dělaný pro Perl v5.10 a s předpokladem, že není problém doinstalovat některé užitečné moduly (např. autodie). Neměl by být problém ho retardovat na starší verzi. Místo autodie použijete klasické ... or die, místo smart match použijete grep a místo given...when použijete if...elsif.
    #!/usr/bin/perl
    
    use strict;
    use warnings;
    
    
    # fetch arguments...
    my @dirs = sort @ARGV;
    @dirs = qw/./ unless scalar @dirs;
    
    my @output;
    
    # walk through directory queue...
    while (my $dir = shift @dirs) {
    
            # include this directory in output...
            push @output, $dir;
    
            # temporary array for directory objects
            # we use this to maintain the already sorted order...
            my @localdirs;
    
            # process all entries in this directory...
            opendir(my $dh, $dir) or die "opendir $dir: $!\n";
            my @entries = readdir($dh);
            die "readdir $dir: $!\n" unless scalar @entries;
            for my $obj (sort @entries) {
                    # skip dot and dotdot...
                    next if grep { $_ eq $obj } (qw/. ../);
    
                    # figure out the full path and process it...
                    my $fp = "$dir/$obj";
    
                    if (-f $fp) {
                            # files go to output...
                            push @output, $fp;
                    }
                    elsif (-d $fp) {
                            # dirs go to temp. array...
                            push @localdirs, $fp;
                    }
            }
    
            # prepend found directories to the queue...
            unshift @dirs, @localdirs if scalar @localdirs;
    }
    
    print join("\n", @output), "\n";
    
    Opět dodávám, že jsem tento program na Vašem systému netestoval, takže si případné drobnosti dolaďte.
    In Ada the typical infinite loop would normally be terminated by detonation.
    28.5.2009 10:06 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    niečo takéto by nepomohlo? (netestované)
    sort {
      (-d $a ? 0 : 1) <=> (-d $b ? 0 : 1)
     || split ('/', $a) <=> split ('/', $b)
     || $a cmp $b
    } @flist
    
    28.5.2009 10:54 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Myslím že tohle by vždy upřednostnilo soubory před adresáři, což není to pravé ořechové. Druhý level by pak asi upřednostnil, pokud si to správně představuju, všechny soubory s jedním lomítkem před dvěma lomítky, atp.

    Problémy tohoto přístupu, i kdyby fungoval, jsou dva:

    1) Sort má složitost n*logn, takže přesně tolik uděláte syscallů stat() - čili budete spoustu souborů statovat duplicitně - to jde vyřešit pomocným polem/schwarzovou transformací.

    2) I kdybyste počet volání stat() linearizoval, tak v podstatě oddřete znova to co už jednou dělal file::find. Jinými slovy snažíte se vydolovat z jednoho pole informaci kterou jste předtím věděl, ale zbavil jste se jí (viz můj příspěvek výše).
    In Ada the typical infinite loop would normally be terminated by detonation.
    nettezzaumana avatar 28.5.2009 15:14 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    diky za odpovedi.

    Vase metoda je dobra, nepochybne lepsi nez ta moje pomoci File::Find .. Jeste se zamyslim, jestli nebude stat za to prepsat to cele po Vasem.
    28.5.2009 15:46 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    skúste ešte zakomponovať tento kúsok:
    my %dirs;
    sub wanted {
      %dirs{$File::Find::dir} = 1;
      ...
    };
    
    a miesto "-d $a" v sorte použiť "exists $dir{$a}"

    takisto môžete použiť:
    my %dirs;
    sub wanted {
      push @{ $dirs{$File::Find::dir} }, $File::Find::name;
    }
    
    a btw, obyčajný sort @list nestačí?
    28.5.2009 16:43 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    To je to pomocné pole (hash) o kterém jsem mluvil, řešící jen půlku problému :)
    In Ada the typical infinite loop would normally be terminated by detonation.
    nettezzaumana avatar 28.5.2009 18:15 nettezzaumana | skóre: 3
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    jenom pro zajimavost, existuje podle Vas nejaka cesta, jak efektivne srovnat obe pole pokud by to bylo moji puvodni metodou .. ??

    ps. nemusite mit strach, prijal jsem Vase reseni, je dobre .. ;)
    29.5.2009 06:47 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Pokud nechcete pro každý adresář procházet celý seznam souborů (jak to dělalo Vaše původní řešení), tak si musíte vybudovat pomocnou datovou strukturu (hash polí), kde rozřadíte soubory na jeden zátah, přibližně takto
    my %files_in;
    for my $file (@files) {
        # Tady potřebujete mít soubory v aktuálním adresáři ve formátu "./soubor"
        # nebo to ještě nějak ošetřit pokud máte pouze "soubor"
        my ($dir_part) = ($file =~ m{^(.*)/.*?$});
        push @{$files_in{$dir_part}}, $file;
    }
    
    (V podstatě to samé co dělal barney už při findování.) Pak byste tu strukturu vypsal (použil) nějak takto:
    for my $dir (sort keys %dirs_to_files) {
        print $dir, "\n",
              join("\n", sort @{$files_in{$dir}}), "\n";
    }
    
    (Opět nezkoušeno.)
    In Ada the typical infinite loop would normally be terminated by detonation.
    29.5.2009 06:48 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Jo, místo toho sort keys %dirs_to_files má být sort keys %files_in.
    In Ada the typical infinite loop would normally be terminated by detonation.
    29.5.2009 11:00 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    sub build_flist {
        my ($fpath) = @_;
    
        my %dirs;
        find (sub { push @{ $dirs{$File::Find::dir} }, $File::Find::name; }, $fpath);
    
        @$_ = sort @$_ for values %dirs;
    
        my @head = @{ delete $dirs{$fpath} };
        my @flist;
    
        while (my $d = shift @head) {
            push @flist, $d;
            unshift @head, @{ delete $dirs{$d} } if exists $dirs{$d};
        }
    
        @flist
    }
    
    $\ = "\n";
    print for build_flist ($ARGV[0])
    
    
    29.5.2009 13:08 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    Tak tahle rutina vypadá dost komplikovaně a zběsile na to, aby už fungovala, ne? Ve skutečnosti to dělá asi tohle:
    sub build_flist {
        my ($fpath) = @_;
    
        my @r;
        find (sub { push @r, $File::Find::name; }, $fpath);
    
        return sort @r;
    }
    
    Čili jednak překombinované a jednak to nedělá to co to má dělat ;-)

    A přečtěte si někdy aspoň knihu perl best practices, za některé výtvory (@$_ = sort @$_ for values %dirs) bych střílel...
    In Ada the typical infinite loop would normally be terminated by detonation.
    29.5.2009 18:47 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    nie celkom, príklad: "dir1", "dir1/1" a "dir1-1"
    30.5.2009 05:19 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: sort v perlu dle cest ..
    V tom máte pravdu, ale na druhou stranu to celé zařadí před "dir2" (i kdyby to byl soubor).
    In Ada the typical infinite loop would normally be terminated by detonation.

    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.