abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Nová verze

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

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

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 9
    včera 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

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

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

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

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

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

    Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.

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

    Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.

    Ladislav Hagara | Komentářů: 2
    včera 04:11 | Nová verze

    Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 741 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    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: 207×
    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.