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

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

    Ladislav Hagara | Komentářů: 14
    dnes 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ářů: 1
    včera 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
    včera 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
    včera 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
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 1
    Kdo vám letos nadělí dárek?
     (29%)
     (3%)
     (10%)
     (3%)
     (1%)
     (3%)
     (15%)
     (21%)
     (15%)
    Celkem 78 hlasů
     Komentářů: 18, poslední dnes 15:30
    Rozcestník

    Dotaz: Seřazení souboru dle pořadí ve druhém souboru

    9.7.2014 12:46 cigi | skóre: 2
    Seřazení souboru dle pořadí ve druhém souboru
    Přečteno: 272×
    Ahoj,

    potřeboval bych poradit, jak v shelovém (bash) skriptu spojit a seřadit 2 soubory. Ten hlavní obsahuje v prvním sloupci ID a k němu v řádku nějaké další informace, je seřazen dle ID. Druhý soubor potom obsahuje jen ID, případně ještě prioritu, dle které je soubor řazen (tedy buď obsahuje v prvním sloupci prioritu a ve druhém ID, nebo jen ID - je to jedno, mohu to použít jak chci).

    Jde mi o to, že potřebuji vykonávat nějaké operace v pořadí dle vypočítané priority pro každou položku dle ID a k tomu jsou potřeba informace z hlavního souboru. Nechce se mi jet dle seznamu s prioritami a pro každou položku prohledávat soubor s podrobnostmi, raději bych to vše spojil dohromady.

    Asi bude existovat nějaké řešení pomocí awk, ale zaprvé s ním moc neumím (a trochu se mi do toho teď nechce) a za druhé si říkám, zda to není příliš těžkotonážní, ideálně bych si představoval nějakou chytrou linuxovou utilitku, která to udělá rychle a jednoduše - něco jako paste. Existuje něco takového?

    Předem děkuji,

    David.

    Odpovědi

    wamba avatar 9.7.2014 14:42 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Seřazení souboru dle pořadí ve druhém souboru
    Když neuvedete příklady těch dvou souborů a jak má vypadat výstup tak je těžká představa co přesně chcete. (Sloupce jsou oddělené čím, jak vypadají ty priority, co jsou nějaké operace atd.) Ale vyřešit to ve vhodném skriptovacím jazyce (Perl, Python, Ruby, AWK, ...) to bude pravděpodobně snadné.
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    9.7.2014 15:01 cigi | skóre: 2
    Rozbalit Rozbalit vše Re: Seřazení souboru dle pořadí ve druhém souboru
    Pravda, díky.

    Soubor dle kterého se má řadit vypadá takto:
    3
    1
    4
    2
    
    Soubor s daty takto:
    1 1.2.3.4 prvni
    2 2.3.4.5 druhy
    3 3.4.5.6 treti
    4 4.5.6.7 ctvrty
    
    výsledek má vypadat takto:
    3 3.4.5.6 treti
    1 1.2.3.4 prvni
    4 4.5.6.7 ctvrty
    2 2.3.4.5 druhy
    
    Soubory nemusí mít stejný počet řádků, řádky bez priorit přijdou nakonec, přebytečné priority se zahodí. Řádku je cca 2500, výrazný růst nebude. Sloupce odděleny mezerou.
    wamba avatar 9.7.2014 16:48 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Seřazení souboru dle pořadí ve druhém souboru
    tak v Perlu třeba takhle
    use 5.010;
    use warnings;
    use strict;
    use File::Slurp qw( :std );
    #use Data::Dumper;
    
    my @razeni = read_file( 'radici_soubor.txt', chomp => 1 );
    my %radici_hash;
    @radici_hash{@razeni} = ( 1 .. @razeni );
    
    #say Dumper( \%radici_hash );
    
    my @data_na_serazeni = read_file('soubor_na_serazeni.txt');
    my @serazena_data =
      map  { $_->[1] }
      sort { $a->[0] <=> $b->[0] }
      map  { [ $radici_hash{ ( split m/\s+/, $_, 2 )[0] } // @razeni + 1, $_ ] }
      @data_na_serazeni;
    
    print @serazena_data;
    1;
    
    
    This would have been so hard to fix when you don't know that there is in fact an easy fix.

    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.