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 21:33 | Humor

Richard M. Stallman v článku Install Fests: What to Do about the Deal with the Devil navrhuje, jak se vypořádat s morálním dilematem, zda na „installfestech“ (akcích, kde zkušení uživatelé pomáhají nováčkům nainstalovat GNU/Linux na přinesený hardware) instalovat také nesvobodný software, typicky ovladače. Vzdělávací přístup je „škola hrou“, kdy instalace právě nesvobodného softwaru provádí postava „Ďábla“.

Fluttershy, yay! | Komentářů: 0
včera 14:44 | Komunita

Dalších sedm produktů od společnosti ThinkPenguin získalo certifikaci RYF (Respects Your Freedom, Respektuje vaši svobodu) udělovanou Nadací pro svobodný software (FSF). Poprvé získal certifikaci USB mikrofon, konkrétně TPE-USBMIC. Certifikace RYF byla představena v říjnu 2012.

Ladislav Hagara | Komentářů: 0
včera 13:33 | Komunita

Na Humble Bundle lze získat počítačovou hru Tacoma (YouTube, Wikipedie) běžící také v Linuxu zdarma. Speciální akce končí v neděli v 18:00.

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

Na Kickstarteru byla spuštěna kampaň na podporu zařízení NexDock 2. Jedná se o přenosnou dokovací stanici aneb notebook bez procesoru a paměti. Stačí připojit podporovaný telefon s Androidem nebo Raspberry Pi.

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

Před týdnem byly vydány nové verze 4.2.11.1, 5.0.7.2, 5.1.6.2, 5.2.2.1 a 6.0.0.beta3 frameworku pro vývoj webových aplikací Ruby on Rails (Wikipedie). Opraveny byly 3 bezpečnostní chyby: CVE-2019-5418, CVE-2019-5419 a CVE-2019-5420. Analýza CVE-2019-5418 (zobrazit si lze libovolný soubor na serveru, například /etc/passwd) na blogu Chybeta.

Ladislav Hagara | Komentářů: 1
21.3. 23:33 | Zajímavý projekt

Na Humble Bundle byla spuštěna akce Humble Book Bundle: Web Programming by O'Reilly. Za 1 dolar a více lze koupit 5 elektronických knih, za 8 dolarů a více lze koupit 11 elektronických knih a za 15 dolarů a více lze koupit 17 elektronických knih věnovaných webovému programování od nakladatelství O'Reilly Media. Část ceny lze určit charitě.

Ladislav Hagara | Komentářů: 0
21.3. 23:00 | Pozvánky

Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 162. brněnský sraz, který proběhne v pátek 22. března od 18:00 v restauraci Slatinský šenk na adrese Zlínská 12.

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

Jonathan Thomas oznámil vydání nové verze 2.4.4 video editoru OpenShot (Wikipedie). Přehled novinek na YouTube. Zdrojové kódy OpenShotu jsou k dispozici na GitHubu. Ke stažení je také balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit.

Ladislav Hagara | Komentářů: 0
21.3. 15:22 | Zajímavý článek

Mozilla.cz informuje, že Firefox bude mít nového správce hesel Lockbox. Lockbox bude integrován s Firefox Monitorem – službou pro varování při únicích dat.

Ladislav Hagara | Komentářů: 0
21.3. 11:33 | Nová verze

Webový prohlížeč Falkon založený na QtWebEngine (Blink) byl vydán ve verzi 3.1. Podle seznamu změn zlepšuje integraci v rámci KDE, opravuje několik chyb a stabilizuje podporu rozšíření v Python a přidává podporu QML.

Fluttershy, yay! | Komentářů: 2
Kolik balíčků (v tisících) máte nainstalovaných na svém systému?
 (4%)
 (13%)
 (34%)
 (30%)
 (19%)
 (3%)
 (2%)
 (1%)
 (3%)
Celkem 229 hlasů
 Komentářů: 22, poslední včera 12:39
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.