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 17:33 | Nová verze

    Byla vydána nová stabilní verze 7.6 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 140. Přehled novinek i s náhledy v příspěvku na blogu.

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

    Byla vydána verze 1.90.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

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

    GNUnet (Wikipedie) byl vydán v nové major verzi 0.25.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.

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

    Byla vydána nová major verze 7.0 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Nově je postavena je na Debianu 13 (Trixie) a GNOME 48 (Bengaluru). Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:44 | IT novinky

    Společnost Meta na dvoudenní konferenci Meta Connect 2025 představuje své novinky. První den byly představeny nové AI brýle: Ray-Ban Meta (Gen 2), sportovní Oakley Meta Vanguard a především Meta Ray-Ban Display s integrovaným displejem a EMG náramkem pro ovládání.

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

    Po půl roce vývoje od vydání verze 48 bylo vydáno GNOME 49 s kódovým názvem Brescia (Mastodon). S přehrávačem videí Showtime místo Totemu a prohlížečem dokumentů Papers místo Evince. Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.

    Ladislav Hagara | Komentářů: 11
    včera 16:22 | Nová verze

    Open source softwarový stack ROCm (Wikipedie) pro vývoj AI a HPC na GPU od AMD byl vydán ve verzi 7.0.0. Přidána byla podpora AMD Instinct MI355X a MI350X.

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

    Byla vydána nová verze 258 správce systému a služeb systemd (GitHub).

    Ladislav Hagara | Komentářů: 6
    včera 15:11 | Nová verze

    Byla vydána Java 25 / JDK 25. Nových vlastností (JEP - JDK Enhancement Proposal) je 18. Jedná se o LTS verzi.

    Ladislav Hagara | Komentářů: 0
    včera 14:44 | Humor

    Věra Pohlová před 26 lety: „Tyhle aféry každého jenom otravují. Já bych všechny ty internety a počítače zakázala“. Jde o odpověď na anketní otázku deníku Metro vydaného 17. září 1999 na téma zneužití údajů o sporožirových účtech klientů České spořitelny.

    Ladislav Hagara | Komentářů: 9
    Jaké řešení používáte k vývoji / práci?
     (39%)
     (55%)
     (6%)
     (9%)
     (12%)
     (9%)
     (12%)
     (9%)
     (15%)
    Celkem 33 hlasů
     Komentářů: 4, poslední dnes 19:18
    Rozcestník

    Dotaz: nefunguje sort

    13.8.2008 16:50 mapim | skóre: 18
    nefunguje sort
    Přečteno: 670×
    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.