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 15:00 | Nová verze

    Všem vše nejlepší do nového roku 2026.

    Ladislav Hagara | Komentářů: 7
    včera 13:33 | Zajímavý software

    Crown je multiplatformní open source herní engine. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT a GPLv3+. Byla vydána nová verze 0.60. Vyzkoušet lze online demo.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | Zajímavý článek

    Daniel Stenberg na svém blogu informuje, že po strncpy() byla ze zdrojových kódů curlu odstraněna také všechna volání funkce strcpy(). Funkci strcpy() nahradili vlastní funkcí curlx_strcopy().

    Ladislav Hagara | Komentářů: 2
    včera 03:00 | Nová verze

    Byla vydána nová verze 25.12.30 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    30.12. 18:55 | IT novinky

    Společnost Valve publikovala přehled To nej roku 2025 ve službě Steam aneb ohlédnutí za nejprodávanějšími, nejhranějšími a dalšími nej hrami roku 2025.

    Ladislav Hagara | Komentářů: 0
    30.12. 16:11 | Komunita

    Byly publikovány výsledky průzkumu mezi uživateli Blenderu uskutečněného v říjnu a listopadu 2025. Zúčastnilo se více než 5000 uživatelů.

    Ladislav Hagara | Komentářů: 0
    30.12. 03:33 | Bezpečnostní upozornění

    V dokumentově orientované databázi MongoDB byla nalezena a v upstreamu již opravena kritická bezpečností chyba CVE-2025-14847 aneb MongoBleed.

    Ladislav Hagara | Komentářů: 0
    29.12. 23:11 | IT novinky

    Při úklidu na Utažské univerzitě se ve skladovacích prostorách náhodou podařilo nalézt magnetickou pásku s kopií Unixu V4. Páska byla zaslána do počítačového muzea, kde se z pásky úspěšně podařilo extrahovat data a Unix spustit. Je to patrně jediný známý dochovaný exemplář tohoto 52 let starého Unixu, prvního vůbec programovaného v jazyce C.

    NUKE GAZA! 🎆 | Komentářů: 14
    29.12. 15:55 | Komunita

    FFmpeg nechal kvůli porušení autorských práv odstranit z GitHubu jeden z repozitářů patřících čínské technologické firmě Rockchip. Důvodem bylo porušení LGPL ze strany Rockchipu. Rockchip byl FFmpegem na porušování LGPL upozorněn již téměř před dvěma roky.

    NUKE GAZA! 🎆 | Komentářů: 7
    29.12. 15:44 | Zajímavý software

    K dispozici je nový CLI nástroj witr sloužící k analýze běžících procesů. Název je zkratkou slov why-is-this-running, 'proč tohle běží'. Klade si za cíl v 'jediném, lidsky čitelném, výstupu vysvětlit odkud daný spuštěný proces pochází, jak byl spuštěn a jaký řetězec systémů je zodpovědný za to, že tento proces právě teď běží'. Witr je napsán v jazyce Go.

    NUKE GAZA! 🎆 | Komentářů: 1
    Kdo vám letos nadělí dárek?
     (29%)
     (1%)
     (28%)
     (1%)
     (1%)
     (1%)
     (10%)
     (10%)
     (18%)
    Celkem 223 hlasů
     Komentářů: 22, poslední včera 15:34
    Rozcestník

    Dotaz: nefunguje sort

    13.8.2008 16:50 mapim | skóre: 18
    nefunguje sort
    Přečteno: 693×
    ahoj, mam takovyto soubor:

    BB000 00000
    BB001 00001
    BB002 00002
    AA000 00000
    AA001 00001
    AA002 00002

    pokud napisu cat file | sort | less, mam z toho toto:
    AA000 00002
    AA001 00001
    AA002 00000
    BB000 00002
    BB001 00001
    BB002 00000

    a ja bych potreboval
    AA000 00000
    AA001 00001
    AA002 00002
    BB000 00000
    BB001 00001
    BB002 00002

    co delam spatne? podle toho, co jsem se docet napriklad tady: http://en.wikipedia.org/wiki/Sort_(Unix), by melo stacit pouhe sort (pracuji na freebsd)
    dekuji za pomoc

    Odpovědi

    13.8.2008 17:06 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort
    Opravdu vám příkaz sort generuje řádky, které v původním vstupním souboru vůbec nebyly? To odporuje nejen dokumentaci, ale mé zkušenosti. Když zkusím ten váš příklad na svém systému, výsledek vypadá jako vaše třetí ukázka.
    Tarmaq avatar 13.8.2008 17:37 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: nefunguje sort
    Me to funguje taky spravne... jste si jist ze mate ten soubor presne takhle?
    Don't panic!
    14.8.2008 02:21 abr | skóre: 24 | blog: ab
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    U me na fbsd7 taky spravne.
    14.8.2008 06:09 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    dekuji za komentare. stravil jsem nad tim hodne casu, a bohuzel musim rict ano, dela to tak, jak jsem popsal. cely muj prikaz zni takto (mozna bude chyba nekde v tady)

    cat soubor | grep -v "*" | grep -v "-" | cut -c25-29,125-130 | sort | less
    14.8.2008 06:13 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    jeste jen doplnim, ze nevygeneruje pred tim neexistujici radky, nybrz druhy sloupec setridi reverzne oproti prvnimu.
    14.8.2008 07:11 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    jsem z toho jelen, pokud pouziji jeste jeden sloupec, ktery tam je k dispozici, setridi se to spravne.

    AA000 0 00000
    AA001 1 00001
    AA002 2 00002
    BB000 0 00000
    BB001 1 00001
    BB002 2 00002
    14.8.2008 08:53 R
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    Cize vygeneruje neexistujuce riadky? Sort funguje tak, ze meni poradie riadkov, nic ine!
    14.8.2008 09:42 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    ne, obsah druheho sloupce je stejny, akorat sloupec 1 je serazen od a-z a sloupec 2 od z-a - coz se nedeje, pokud pouziji jeste jeden slopec, pak je treti sloupec v poradku serazen. prikaz vypada tedy takto:

    grep -v "*" soubor | grep -v "-" | cut -c25-29,39-40,125-130 | awk 'BEGIN { FS=" " } { print ($1,$2,$3 / 1000); }' >1;
    14.8.2008 09:46 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    teda takhle:
    grep -v "*" soubor | grep -v "-" | cut -c25-29,39-40,125-130 | sort | awk 'BEGIN { FS=" " } { print ($1,$2,$3 / 1000); }' | less
    14.8.2008 12:10 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?

    No to prave nemuze nastat. Lze sortu rict, aby jako klic k porovnani pouzil treba druhy sloupecek, ale vzdycky bude soupat s celymi radky, neexistuje aby si "vymyslel" svoje vlastni.

    Jeste bych se podival, co presne do sortu posilate, tedy do souboru si presmeroval vysledek toho vseho pred | sort, a pak to normalne pustil na cistej sort (sort < input.txt), schvalne, co z toho vznikne.

    14.8.2008 12:28 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    pokud zadam prikaz:
    grep -v "*" text0 | grep -v "-" | cut -c25-29,125-130 >text1;sort <text1 | less
    je to to same, pokud vsak zadam prikaz:
    grep -v "*" ftext0 | grep -v "-" | cut -c25-29,39-40,125-130 >text1;sort <text1
    je to v pohode
    14.8.2008 12:37 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    Hoďte sem (do přílohy) ukázku vstupu, na kterém se to projeví. Jinak se nejspíš dál nepohneme.
    14.8.2008 09:09 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    Ale to by opravdu znamenalo, že na výstupu příkazu sort dostanete řádky, které na vstupu nebyly.
    14.8.2008 09:21 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    Hm... a jak přesně vypadá ten vstup, který do toho posíláte?
    14.8.2008 09:44 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    mohu zaslat na mejl, jestli mate zajem
    14.8.2008 12:03 abr | skóre: 24 | blog: ab
    Rozbalit Rozbalit vše Re: Co znamena za FreeBSD 7.0 znacka p3 ?
    Dej to sem do prilohy (staci par "neskodnych" radku).
    14.8.2008 13:04 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: nefunguje sort
    vstup:
    0 1 AB001 0 0 11311 1 1 720864 208552 16000 60000 11 8 12 12 26 30 3 512
    0 1 AB001 1 0 11312 1 1 720864 208552 8000 60000 11 8 12 12 26 30 3 512
    0 1 AB001 2 0 11313 1 1 720864 208552 16000 60000 11 8 12 12 26 30 3 512
    0 1 AG001 0 0 11311 1 1 720864 208552 16000 60000 11 8 12 12 26 30 3 512
    0 1 AG001 1 0 11312 1 1 720864 208552 4000 60000 11 8 12 12 26 30 3 512
    0 1 AG001 2 0 11313 1 1 720864 208552 9 60000 11 8 12 12 26 30 3 512
    prikazem
    grep -v "*" SOUBOR | grep -v "-" | cut -c25-29,39-40,125-130 | sort | awk 'BEGIN { FS=" " } { print ($1,$2,$3 / 1000 ); }' | less
    si udelam takovyto vystup:
    AB001 0 16
    AB001 1 8
    AB001 2 16
    AG002 0 16
    AG002 1 4
    AG002 2 9
    pokud vsak vynecham prostredni sloupecek (ktery az tak nepotrebuji - nikomu nezavazi) a z prikazu cut -c25-29,39-40,125-130 udelam cut -c25-29,125-130, sort prestane fungovat.

    - jako dalsi dotaz mam (nikde jsem nenasel) jak pridat sloupecek z externiho souboru za tyhle dalsi sloupce? moc dekuji

    14.8.2008 13:25 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort

    Nemáte pravdu, sort funguje pořád, jen dělá to, co má, ne co vy si představujete. Neuvedete-li klíč, řadí se celé řádky jako řetězce. V tomto smyslu platí např.

      'AG001 16000' < 'AG001 4000' < 'AG001 9'
    

    P.S.: ani výstup, který uvádíte, neodpovídá vstupu, který uvádíte.

    14.8.2008 13:42 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort

    Ještě doplnění: pokud jsem dobře pochopil, že potřebujete řadit podle prvního sloupce textově a jako druhé kritérium podle druhého sloupce číselně, použijte

      sort  -k 1,1 -k 2n
    
    14.8.2008 13:22 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: nefunguje sort
    nemam dneska stasty den, tady je konecne spravne popsany vstup a vystup:

    vstup:
    0 1 AG002 0 0 11311 1 1 720864 208552 16000 60000 11 8 12 12 26 30 3 512
    0 1 AG002 1 0 11312 1 1 720864 208552 4000 60000 11 8 12 12 26 30 3 512
    0 1 AG002 2 0 11313 1 1 720864 208552 9000 60000 11 8 12 12 26 30 3 512
    0 1 BC050 0 0 11311 1 1 720864 208552 14000 60000 11 8 12 12 26 30 3 512
    0 1 BC050 1 0 11312 1 1 720864 208552 3000 60000 11 8 12 12 26 30 3 512
    0 1 BC050 2 0 11313 1 1 720864 208552 6000 60000 11 8 12 12 26 30 3 512
    0 1 AB001 0 0 11311 1 1 720864 208552 16000 60000 11 8 12 12 26 30 3 512
    0 1 AB001 1 0 11312 1 1 720864 208552 8000 60000 11 8 12 12 26 30 3 512
    0 1 AB001 2 0 11313 1 1 720864 208552 16000 60000 11 8 12 12 26 30 3 512
    prikazem
    grep -v "*" SOUBOR | grep -v "-" | cut -c25-29,39-40,125-130 | sort | awk 'BEGIN { FS=" " } { print ($1,$2,$3 / 1000 ); }' | less
    si udelam takovyto vystup:
    AB001 0 16
    AB001 1 8
    AB001 2 16
    AG002 0 16
    AG002 1 4
    AG002 2 9
    BC050 0 14
    BC050 1 3
    BC050 2 6
    pokud vsak vynecham prostredni sloupecek (ktery az tak nepotrebuji - nikomu nezavazi) a z prikazu cut -c25-29,39-40,125-130 udelam cut -c25-29,125-130, sort prestane fungovat.

    - jako dalsi dotaz mam (nikde jsem nenasel) jak pridat sloupecek z externiho souboru za tyhle dalsi sloupce? moc dekuji


    14.8.2008 13:29 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort
    Používejte element pre, vzhledem k použití příkazu 'cut -c' záleží velmi výrazně na rozložení mezer. Vstup, který jste teď uvedl, ani zdaleka nevede na výstup, který uvádíte. Tentokrát navíc ani po zkopírování přímo ze zdrojáku stránky.
    14.8.2008 13:57 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: nefunguje sort
    vstup:
    1           22          AG002          0           0            51071       1           1           708814      238794       16000       60000         51          8             12            12            26             30              3                512     
    1           22          AG002          1           0            51072       1           1           708814      238794       3000        60000         51          8             12            12            26             30              3                512     
    1           22          AG002          2           0            51073       1           1           708814      238794       13000       60000         51          8             12            12            26             30              3                512     
    1           23          BC050          1           0            53182       1           1           717549      263015       5000        60000         53          8             12            12            26             30              3                256     
    1           23          BC050          2           0            53183       1           1           717549      263015       16000       60000         53          8             12            12            26             30              3                256     
    1           24          BC050          0           0            53073       1           1           719191      257662       3000        60000         53          8             12            12            26             30              3                256     
    1           25          AB001          0           0            53092       1           1           719173      257959       3000        60000         53          8             12            12            26             30              3                512     
    1           25          AB001          1           0            53093       1           1           719173      257959       2000        60000         53          8             12            12            26             30              3                512     
    1           26          AB001          0           0            55151       1           1           713840      231034       16000       60000         74          8             12            12            26             30              3                512     
    1           26          VY015          1           0            55152       1           1           713840      231034       16000       60000         55          8             12            12            26             30              3                512     
    1           26          VY015          2           0            55153       1           1           713840      231034       16000       60000         55          8             12            12            26             30              3                512     
    

    prikaz:
    grep -v "*" soubor | grep -v "-" | cut -c25-29,39-40,125-130 | sort | awk 'BEGIN { FS=" " } { print ($1,$2,$3 / 1000 ); }' | less

    vystup
    AB001 0 16
    AB001 0 3
    AB001 1 2
    AG002 0 16
    AG002 1 3
    AG002 2 13
    BC050 0 3
    BC050 1 5
    BC050 2 16
    VY015 1 16
    VY015 2 16
    
    14.8.2008 14:01 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort
    Ano, takový výstup je naprosto v pořádku. Viz odpověď výše.
    14.8.2008 16:03 mapim | skóre: 18
    Rozbalit Rozbalit vše Re: nefunguje sort
    ano, ale bez prostredniho sloupce je to sptane. vi nekdo proc?
    $ grep -v "*" soubor | grep -v "-" | cut -c25-29,125-130 | sort | awk 'BEGIN { FS=" " } { print ($1,$2 / 1000 ); }' | less
    AB001 16
    AB001 2
    AB001 3
    AG002 13
    AG002 16
    AG002 3
    BC050 16
    BC050 3
    BC050 5
    VY015 16
    VY015 16
    $ grep -v "*" soubor | grep -v "-" | cut -c25-29,39-40,125-130 | sort | awk 'BEGIN { FS=" " } { print ($1,$2,$3 / 1000 ); }' | less
    AB001 0 16
    AB001 0 3
    AB001 1 2
    AG002 0 16
    AG002 1 3
    AG002 2 13
    BC050 0 3
    BC050 1 5
    BC050 2 16
    VY015 1 16
    VY015 2 16
    
    14.8.2008 16:08 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort
    Ne, je to naprosto v pořádku. Vysvětlení máte v mém příspěvku z 13:25 a způsob, jak dosáhnout toho, co chcete, v mém příspěvku z 13:42. Howgh
    14.8.2008 14:31 Jirka P
    Rozbalit Rozbalit vše Re: nefunguje sort
    Když jsem vyhodil prostřední sloupec z cutu, tak mi vylezlo
    AB001 16000 0
    AB001 2000 0
    AB001 3000 0
    AG002 13000 0
    AG002 16000 0
    AG002 3000 0
    BC050 16000 0
    BC050 3000 0
    BC050 5000 0
    VY015 16000 0
    VY015 16000 0
    
    Nepřipadá mi to špatně. Vám ano?

    Pro připojení dalšího sloupce zkuste příkaz paste, ale tam budete mít problém, že zarovnáváte mezerami, což nevím jak by se dělalo.
    14.8.2008 16:33 maleprase | skóre: 28
    Rozbalit Rozbalit vše Re: nefunguje sort
    1. bych ten sort dal uplne nakonec

    2. je potreba si uvedomit ze sort bez parametru tridy retezce ne cisla takze "2" > "16"
    14.8.2008 17:24 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: nefunguje sort
    Bývá dobré si nejdřív přečíst předchozí odpovědi.

    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.