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:22 | Zajímavý projekt

Na Humble Bundle lze v rámci akce Humble Book Bundle: Linux Geek by No Starch Press zakoupit elektronické knihy věnované operačnímu systému Linux a open source softwaru od nakladatelství No Starch Press a navíc podpořit charitu. Za 1 dolar a více lze zakoupit 6 elektronických knih, za 8 dolarů a více dalších 6 elektronických knih, za 15 dolarů a více dalších 5 elektronických knih a za 30 dolarů a více další elektronickou knihu navíc.

Ladislav Hagara | Komentářů: 0
dnes 01:33 | Komunita

Patrick Volkerding oznámil před pětadvaceti lety vydání Slackware Linuxu 1.00. Slackware Linux byl tenkrát k dispozici na 3,5 palcových disketách. Základní systém byl na 13 disketách. Kdo chtěl grafiku, potřeboval dalších 11 disket. Slackware Linux 1.00 byl postaven na Linuxu .99pl11 Alpha, libc 4.4.1, g++ 2.4.5 a XFree86 1.3.

Ladislav Hagara | Komentářů: 15
včera 17:33 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na jednodeskový počítač Renegade Elite. Měl by být 4x výkonnější než Raspberry Pi 3 Model B+. Vlastnit jej lze již v září. Aktuální cena je 99 dolarů.

Ladislav Hagara | Komentářů: 14
včera 12:44 | Komunita

Od 7. do 10. června proběhla v Berlíně Linux Audio Conference 2018. Na programu byla řada zajímavých přednášek, seminářů a vystoupení. Videozáznamy lze zhlédnout na media.ccc.de.

Ladislav Hagara | Komentářů: 0
včera 09:44 | Pozvánky

Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.

xkucf03 | Komentářů: 0
14.7. 22:44 | Nová verze

Bylo oznámeno vydání KDE Frameworks 5.48.0, tj. nové verze aktuálně 72 knihoven rozšířujících multiplatformní framework Qt. Řešena je mimo jiné bezpečnostní chyba CVE-2018-10361 v KTextEditoru zneužitelná k lokální eskalaci práv. Knihovny KDE Frameworks jsou dnes využívány nejenom KDE Plasmou a KDE Aplikacemi.

Ladislav Hagara | Komentářů: 6
14.7. 20:11 | Nová verze

Byl vydán Debian 9.5, tj. pátá opravná verze Debianu 9 s kódovým názvem Stretch. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Předchozí instalační média Debianu 9 Stretch lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

Ladislav Hagara | Komentářů: 15
13.7. 23:55 | Komunita

V Národní technické knihovně (NTK) je 150 nových počítačů s operačním systémem Linux, konkrétně s linuxovou distribucí Fedora. Do konce prázdnin si na nich lze zahrát počítačovou hru Factorio (Wikipedie). V pondělí 23. 7. proběhne LAN party s vývojáři této hry.

Ladislav Hagara | Komentářů: 0
13.7. 17:33 | Zajímavý software

Fanatical (Wikipedie) má ve slevě řadu počítačových her běžících také na Linuxu. Balíček her Fanatical Strategy Bundle lze koupit za 1,99 eur.

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

Byla vydána počítačová hra Warhammer 40,000: Gladius - Relics of War běžící také na Linuxu. Koupit ji lze na GOG, Humble Store i na Steamu. Videoukázka na YouTube.

Ladislav Hagara | Komentářů: 0
Jak čtete delší texty z webových stránek?
 (78%)
 (20%)
 (4%)
 (7%)
 (2%)
 (10%)
Celkem 358 hlasů
 Komentářů: 40, poslední 29.6. 10:21
    Rozcestník

    Dotaz: jak smazat uppercase soubory

    5.1.2006 18:49 pol
    jak smazat uppercase soubory
    Přečteno: 149×
    Jak se dají smazat soubory v adresáři, které jsou velkými písmeny nejlépe přímo z bashe?

    Nebo jinak jak nacpat k rm aby smazal jenom [A-Z] soubory? ..omlouvám se, je to stupidní ale nic mě nenapadá, tj. ani pod čím bych to našel... (Když nic tak aspoň script, please ;) )

    Odpovědi

    5.1.2006 19:12 #Tom
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    rm $(ls | egrep '^[A-Z]+$')
    
    5.1.2006 19:22 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Dík, zní to dobře - ale nefunguje to.

    rm: too few arguments Try `rm --help' for more information.

    je přesně to co to vrátí. Jinak soubory mají tvar XXX.xxxXXX~1.xxx, typická ošklivá DOS jména...
    5.1.2006 19:29 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Zkusil jsem tohle rm "$(ls |egrep '^[A-Z]+.h3m')"

    a vrátilo mi to: cannot remove \nXXX.h3m

    Takže už zbývá jenom odtázka jak převést \n na mezeru?
    David Watzke avatar 5.1.2006 19:38 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    To co napsal #Tom počítá s tím, že v názvu budou JEN velká písmena... musíš se umět vyjadřovat. Jak převést \n na mezeru? RTFM! :-) man sed
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    5.1.2006 19:52 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    No pokud umíš zabránit tomu generování /n nebo ho opravit v následujícím příkazu budu ti jen vděčný.

    rm "$(ls | egrep '^[A-Z][A-Z]+.h3m')"

    ..operace je prováděna na FAT32 disku ..dotaz jsem dodatečně upřesnil
    5.1.2006 20:06 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Spíš man bash, speciálně QUOTING a zrušit ty uvozovky. Pokud jsou v těch jménech mezery, tak man find, zvláště volba -print0.
    David Watzke avatar 5.1.2006 19:40 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    To nepůjde, ne? ls hodí na jeden řádek víc jmen a s tím se (e)grep neporadí...
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    David Watzke avatar 5.1.2006 19:41 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    s/se/si/
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    5.1.2006 19:49 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    To dělá jen tehdy, je-li výstupem terminál.
    5.1.2006 19:51 #Tom
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Ale poradí. Ten příkaz skutečně vymaže všechny soubory, které se skládají výhradně z velkých písmen. Pokud tam mají být i mezery, je to horší:
    for i in *; do
      if [ "$(echo $i | egrep '^[A-Z ]+$')" ]; then
        rm "$i"
      fi
    done
    
    5.1.2006 19:54 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    mezery tam skutečně mohou být... - je to DOS 8.3 name, tudíž i s mezerami
    5.1.2006 20:05 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    mimo mezer jsou tam somzřejmě i jiné znaky - jako ~ a číslo/a
    5.1.2006 20:18 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    samozřejmě jsou tam i jiné znaky jako - nebo _.

    Takže jak?
    5.1.2006 20:22 #Tom
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Třeba [A-Z,.-_ ], všechny znaky povolené znaky v DOSu si už prostě nepamatuju. ;-)
    5.1.2006 20:30 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Aha.

    No ale teď už to funguje perfektně.

    To jak zapisovat správně reg exp do bashe by se ale mohlo přidat do FAQ, no ne?

    ;-)
    5.1.2006 20:18 pol
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    samozřejmě jsou tam i jiné znaky jako - nebo _.

    Takže jak?
    5.1.2006 20:25 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Mám pocit, že mi přeskočilo
    hynek[~]$ echo a | egrep '[A-Z]'
    a
    hynek[~]$ 
    
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    5.1.2006 20:28 #Tom
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Nemělo to být spíš echo a | egrep '[A-Z]*'? To by bylo v pořádku.
    5.1.2006 20:41 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Nepochopil jsi patrně pointu. Ve výstupu z echo a není vůbec žádný znak z ropzsahu [A-Z]. Mě se ta úloha nedaří vyřešit jinak, než grep -v '[a-z]'. Můj grep i bash si prostě myslí, že když napíšu [A-Z], měl jsem patrně na mysli [a-zA-Z] a asi jsem byl jen línej.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    5.1.2006 20:47 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Perl jak se zdá za mě myslet nehodlá. Začínám být na [e]grep a bash poněkud nas...
    echo a | perl -ne 'm/[A-Z]/ && print'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    5.1.2006 20:50 #Tom
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Je to zvláštní. S takovým chováním jsem se nikdy nesetkal a předpokládal jsem, že jde jen o nějaký překlep.
    5.1.2006 21:06 Dunric | skóre: 21
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Pointa je v např. přímo v manuálu ke grepu ;-)
    "Many locales sort characters in dictionary order, and in these locales [a-d] is typically not equivalent to [abcd]; it might be equivalent to [aBbCcDd], for example. To obtain the traditional interpretation of bracket expressions, you can use the C locale by setting the LC_ALL environment variable to the value C."

    Takže následující funguje podle očekávání:

    dunric@darkstar:~$ echo a | LC_ALL=C grep '[A-Z]'
    dunric@darkstar:~$
    
    dunric@darkstar:~$ echo A | LC_ALL=C grep '[A-Z]'
    A
    dunric@darkstar:~$
    
    In the garden sleeps a messenger ·
    5.1.2006 21:10 Dunric | skóre: 21
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Aha, takže jsem nakonec nesl dříví do lesa místo na ohniště ;-)
    In the garden sleeps a messenger ·
    5.1.2006 21:03 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Nějaké srandovní nastavení locales? Mně to funguje, ale chtěl jsem jen tak ze zvědavosti zkusit, jak fungují non-ascii rozsahy, a bum
    $ locale
    LANG=cs_CZ.UTF-8
    LC_CTYPE="cs_CZ.UTF-8"
    LC_NUMERIC="cs_CZ.UTF-8"
    LC_TIME="cs_CZ.UTF-8"
    LC_COLLATE=C
    LC_MONETARY="cs_CZ.UTF-8"
    LC_MESSAGES="cs_CZ.UTF-8"
    LC_PAPER="cs_CZ.UTF-8"
    LC_NAME="cs_CZ.UTF-8"
    LC_ADDRESS="cs_CZ.UTF-8"
    LC_TELEPHONE="cs_CZ.UTF-8"
    LC_MEASUREMENT="cs_CZ.UTF-8"
    LC_IDENTIFICATION="cs_CZ.UTF-8"
    LC_ALL=
    $ grep '[á-é]'
    Neoprávněný přístup do paměti (SIGSEGV)
    
    :-( Zkusím se na to někdy o víkendu kouknout...
    5.1.2006 21:07 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Tak to je taky dobré. grep namá, jak se zdá, regexp připravený na unicode.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    5.1.2006 21:04 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: jak smazat uppercase soubory
    Takže odpovím si sám. RTFM.
           Within a bracket expression, a range expression consists of two charac-
           ters separated by a hyphen.  It matches any single character that sorts
           between the two characters, inclusive,  using  the  locale's  collating
           sequence  and  character  set.   For  example, in the default C locale,
           [a-d] is equivalent to [abcd].  Many locales sort characters in dictio-
           nary  order,  and in these locales [a-d] is typically not equivalent to
           [abcd]; it might be equivalent to [aBbCcDd], for  example.   To  obtain
           the  traditional interpretation of bracket expressions, you can use the
           C locale by setting the LC_ALL environment variable to the value C.
    
    To je ale záludnost :-(
    hynek[~]$ LC_ALL=C
    hynek[~]$ echo a | egrep '[A-Z]'
    hynek[~]$
    Řešením je samozřejmě použít i [:upper:]. Funguje to například i v
    rm [[:upper:]]*
    případně
    find -name '[[:upper:]]*' -print0 | xargs -0 rm
    (Maže soubory začínající na velké písmeno)
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.

    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.