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:50 | Komunita

Nadace The Document Foundation (TDF) zastřešující vývoj svobodného kancelářského balíku LibreOffice slaví 5 let od svého oficiálního vzniku. Nadace byla představena 28. září 2010. Formálně byla založena ale až 17. února 2012.

Ladislav Hagara | Komentářů: 0
dnes 12:50 | Komunita

Mozilla.cz informuje, že dosud experimentální funkce Page Shot z programu Firefox Test Pilot (zprávička) se stane součástí Firefoxu. Page Shot je nástroj pro vytváření snímků webových stránek. Umí výběr oblasti, prvku stránky (např. odstavce), nebo uložení snímku celé stránky. Snímky lze ukládat na disk nebo nahrávat na server Mozilly. Nedávno bylo oznámeno, že se součástí Firefoxu stane Activity Stream.

Ladislav Hagara | Komentářů: 2
dnes 04:10 | Nová verze

Po 10 týdnech vývoje od vydání Linuxu 4.9 (zprávička) oznámil Linus Torvalds, mj. již 20 let žijící v USA, vydání Linuxu 4.10 (LKML). Přehled nových vlastností a vylepšení například na Kernel Newbies a v Jaderných novinách (1, 2 a 3). Kódové jméno Linuxu 4.10 je Fearless Coyote.

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

Vyzkoušet si příkazy a vyřešit několik úkolů lze na stránkách Commandline Challenge (CMD Challenge). Úkoly lze řešit různými způsoby, důležitý je výsledek. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

Ladislav Hagara | Komentářů: 16
18.2. 17:35 | Bezpečnostní upozornění

Německá Bundesnetzagentur (obdoba českého ČTU) zakázala na německém území prodej panenky Cayla kvůli „špionáži“ dětí. Tato elektronická hračka obsahuje mikrofon, reproduktor a kameru a bezdrátové komunikační rozhraní, pomocí kterého se hračka připojuje na servery výrobce. Takovýmto způsobem může hračka pomocí umělé inteligence „odpovídat“ na dotazy dítěte. Hlavní problém bude ale asi někde jinde, podle prvotních zpráv může

… více »
Petr Tomášek | Komentářů: 28
17.2. 15:30 | Bezpečnostní upozornění

CSIRT.CZ upozorňuje, že bezpečnostní experti objevili nový typ malwaru, jenž cílí na open source e-commerce platformu Magento. Malware je zajímavý tím, že se jedná o první svého druhu, jehož kód zůstává skrytý v SQL databázi zasaženého e-shopu. Škodlivý kód je volán pomocí tzv. SQL trigerru, který je spouštěn při každém vytvoření objednávky v systému.

Ladislav Hagara | Komentářů: 3
17.2. 09:00 | Nová verze

Bylo vydáno Ubuntu 16.04.2 LTS, tj. druhé opravné vydání Ubuntu 16.04 LTS s kódovým názvem Xenial Xerus. Přehled novinek v poznámkách k vydání a v přehledu změn.

Ladislav Hagara | Komentářů: 56
17.2. 06:00 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje tvorbě pluginů (modulů) pro bitmapový grafický editor GIMP. Pomocí pluginů lze GIMP rozšiřovat o další funkce. Implementovat lze například nové filtry nebo pomocné utility pro tvorbu animací či poloautomatickou retuš snímků.

Ladislav Hagara | Komentářů: 6
16.2. 23:32 | Komunita

Do 30. března se lze přihlásit do dalšího kola programu Outreachy, jehož cílem je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny. Za 3 měsíce práce, od 30. května do 30. srpna 2017, v participujících organizacích lze vydělat 5 500 USD. Jedná se již o 14. kolo tohoto programu.

Ladislav Hagara | Komentářů: 11
16.2. 23:13 | Nová verze

Byla vydána verze 0.92.1 svobodného multiplatformního vektorového grafického editoru Inkscape. Přehled novinek v poznámkách k vydání. Řešen je mimo jiné problém s verzí 0.92, jež rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Více v příspěvku na blogu Davida Revoye, autora open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 666 hlasů
 Komentářů: 53, poslední dnes 18:38
Rozcestník
Reklama

Dotaz: Filtrování slov v souboru

19.3.2013 13:37 Makr
Filtrování slov v souboru
Přečteno: 228×
Mám textový soubor, který obsahuje konfigurační řádky. Na jednotlivých řádcích se nachází buď relativní/absolutní cesta, nebo název souboru, před nímž je slovo ignore (př.: ignore readme nebo ignore ../*) Chtěla bych vyfiltrovat pouze ignore a následně z nich názvy jednotlivých souborů a s nimi dál pracovat. Zkoušela jsem to řešit pomocí grepu a sedu (grep -v '^ignore .*' sed 's/^*/d/' > soubor), ale to mi shell bohužel nesežral. Nemáte někdo nápad, jak to řešit?

Předem díky za reakce.

Řešení dotazu:


Odpovědi

19.3.2013 13:54 Kit
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Ta hvězdička v parametrech sedu má patřit k "^"? Zřejmě tam něco chybí. Nebo jsi nepochopila, co ta hvězdička v regulárních výrazech znamená.

Mělo by to jít i bez toho grepu.
19.3.2013 13:55 rastos | skóre: 60 | blog: rastos
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
awk '/ignore/ { print $2 }'
19.3.2013 14:11 Kit
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Jestli jsem správně pochopil dotaz z pokusu o řešení, tak by to mohlo být spíš
awk '! /^ignore/ { print $1 }'
Řešení 1× (Makr (tazatel))
19.3.2013 15:11 Ash | skóre: 53
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
grep -v '^ignore .*' sed 's/^*/d/' > soubor
^--příkaz            ^---další příkaz
...ale příkazy se v shellu musí oddělovat nečím víc než mezerou, např. rourou |
grep -v '^ignore .*' sed 's/^*/d/' > soubor
      ^--- chcete vybrat pouze řádky, kde je ignore? Ale -v znamená "vyjma..."
           čili to vybere řádky, kde *není* na začátku ignore.
grep '^ignore .*' soubor | sed 's/^*/d/' > soubor
                  ^      ^        ^  ^--- d (ale v jiném kontextu) maže celý řádek, ne jen slovo, nedejte tam nic a slovo bude nahrazeno mezerou (=vymazáno)
                  |      |        `-- zde má být regulární výraz (regexp), ne wildcard!!!
                  |      `-- to je ta roura
                  `--- grep potřebuje jako parametr soubor, který má zpracovávat
Takže jste asi chtěla napsat něco takového:
grep '^ignore' soubor | sed -e 's/^[^\s]\+\s\+//'
Což lze rovnou v sedu udělat takto:
sed -n -e "s/^ignore\s\+\(.*\)$/\1/p" soubor
19.3.2013 17:08 Makr
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Omlouvám se, o rouře samozřejmě vím, jen mi vypadla.

Ano, původně jsem zamýšlela, že nejdřív si vyfiltruji ty řádky, kde není ignore a ty pak smažu a dál s tím dál budu pracovat. Prosím Vás, vysvětlil bystě mi, co za tím ignore vše značí? Nemůžu si to dát do souvislosti.
20.3.2013 23:56 Ash | skóre: 53
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Ano, původně jsem zamýšlela, že nejdřív si vyfiltruji ty řádky, kde není ignore a ty pak smažu a dál s tím dál budu pracovat.

To by šlo příkazem:
sed -e "/^ignore/d" soubor.txt > soubor_bez_ignore.txt
existuje i parametr -i kterým přepíšete původní soubor.txt.

Pokud byste to chtěla pomocí grep tak:
grep -v "^ignore" soubor.txt > soubor_bez_ignore.txt
a dál pak pracovat s novým souborem.

co za tím ignore vše značí?
sed -n -e "s/^ignore\s\+\(.*\)$/\1/p" soubor
Je to především regulární výraz, regular expression, regexp.
\s = bílý znak, zpravidla mezera, tabulátor apod.
\+ = opakující se alespoň jednou
\(.*\) = jakýkoliv řetězec, v závorkách je to proto, abych ten text mohl následně použít zápisem \1
$ = konec řádku

\1 = zde bude vložen text z první (výše uvedené) závorky, a protože tam toho víc není,
celý výraz vlevo bude nahrazen jen "obsahem" té závorky, což by měl být ten
název souboru.
Před znaky + ( ) jsou obrácená lomítka, protože je nutné je v uvedeném kontextu escapovat, jinak by byly považovány prostě za znak plus, závorka apod. a neměly by zvláštní význam. Sed umí i perlovskou notaci regulárních výrazů, kde je escapování méně.

20.3.2013 23:57 Ash | skóre: 53
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Omlouvám se ten první sed filtruje naopak řádky kde ignore je.
21.3.2013 09:10 Makr
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Děkuji, moc mi to pomohlo.
21.3.2013 14:10 #
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Osobne preferuji prepinac -r mist -e clovek pak nemusi vsude cpat escape \

sed -n -r "s/^ignore\s+(.*)$/\1/p" ./fl.log
20.3.2013 08:43 cronin | skóre: 48
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
grep "^ignore " | cut -f 2- -d " "
21.3.2013 00:00 Ash | skóre: 53
Rozbalit Rozbalit vše Re: Filtrování slov v souboru
Tak cut mám také rád, bohužel je při své jednoduchosti často nanic, protože člověka tak trochu tlačí do nerealistických předpokladů, jako že mezi ignore a názvem souoru je zrovna mezera, a navíc jen jedna apod.

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.