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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 0
dnes 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
včera 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

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

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 8
včera 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 2
včera 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
včera 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 0
včera 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
1.12. 21:00 | Nová verze

Byla vydána beta verze Linux Mintu 18.1 s kódovým jménem Serena. Na blogu Linux Mintu jsou hned dvě oznámení. První o vydání Linux Mintu s prostředím MATE a druhé o vydání Linux Mintu s prostředím Cinnamon. Stejným způsobem jsou rozděleny také poznámky k vydání (MATE, Cinnamon) a přehled novinek s náhledy (MATE, Cinnamon). Linux Mint 18.1 bude podporován až do roku 2021.

Ladislav Hagara | Komentářů: 0
1.12. 16:42 | Nová verze

Byl vydán Devuan Jessie 1.0 Beta 2. Jedná se o druhou beta verzi forku Debianu bez systemd představeného v listopadu 2014 (zprávička). První beta verze byla vydána v dubnu letošního roku (zprávička). Jedna z posledních přednášek věnovaných Devuanu proběhla v listopadu na konferenci FSCONS 2016 (YouTube, pdf).

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 767 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Filtrování slov v souboru

19.3.2013 13:37 Makr
Filtrování slov v souboru
Přečteno: 223×
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.