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 13:00 | Humor

    OpenChaos.dev je 'samovolně se vyvíjející open source projekt' s nedefinovaným cílem. Každý týden mohou lidé hlasovat o návrzích (pull requestech), přičemž vítězný návrh se integruje do kódu projektu (repozitář na GitHubu). Hlasováním je možné změnit téměř vše, včetně tohoto pravidla. Hlasování končí vždy v neděli v 9:00 UTC.

    NUKE GAZA! 🎆 | Komentářů: 1
    dnes 03:00 | Nová verze

    Byl vydán Debian 13.3, tj. třetí opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.13, tj. třináctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    včera 03:00 | Komunita

    Na stránkách Evropské komise, na portálu Podělte se o svůj názor, se lze do 3. února podělit o názor k iniciativě Evropské otevřené digitální ekosystémy řešící přístup EU k otevřenému softwaru.

    Ladislav Hagara | Komentářů: 6
    9.1. 19:44 | Zajímavý software

    Společnost Kagi stojící za stejnojmenným placeným vyhledávačem vydala (𝕏) alfa verzi linuxové verze (flatpak) svého proprietárního webového prohlížeče Orion.

    Ladislav Hagara | Komentářů: 4
    9.1. 19:11 | IT novinky

    Firma Bose se po tlaku uživatelů rozhodla, že otevře API svých chytrých reproduktorů SoundTouch, což umožní pokračovat v jejich používání i po plánovaném ukončení podpory v letošním roce. Pro ovládání také bude stále možné využívat oficiální aplikaci, ale už pouze lokálně bez cloudových služeb. Dokumentace API dostupná zde (soubor PDF).

    NUKE GAZA! 🎆 | Komentářů: 2
    9.1. 14:22 | Zajímavý článek

    Jiří Eischmann se v příspěvku na svém blogu rozepsal o open source AdGuard Home jako domácí ochraně nejen před reklamou. Adguard Home není plnohodnotným DNS resolverem, funguje jako DNS forwarder s možností filtrování. To znamená, že když přijme DNS dotaz, sám na něj neodpoví, ale přepošle ho na vybraný DNS server a odpovědi zpracovává a filtruje dle nastavených pravidel a následně posílá zpět klientům. Dá se tedy používat k blokování reklamy a škodlivých stránek a k rodičovské kontrole na úrovni DNS.

    Ladislav Hagara | Komentářů: 7
    9.1. 03:33 | Zajímavý software

    AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.

    Ladislav Hagara | Komentářů: 1
    9.1. 00:11 | Nová verze

    Byla vydána prosincová aktualizace aneb nová verze 1.108 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.108 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.1. 20:44 | IT novinky

    Na lasvegaském veletrhu elektroniky CES byl předveden prototyp notebooku chlazeného pomocí plazmových aktuátorů (DBD). Ačkoliv se nejedná o první nápad svého druhu, nepochybně to je první ukázka praktického použití tohoto způsobu chlazení v běžné elektronice. Co činí plazmové chladící akční členy technologickou výzvou je především vysoká produkce jedovatého ozonu, tu se prý podařilo firmě YPlasma zredukovat dielektrickou

    … více »
    NUKE GAZA! 🎆 | Komentářů: 14
    8.1. 16:33 | Zajímavý projekt

    Patchouli je open source implementace EMR grafického tabletu (polohovací zařízení). Projekt je hostován na GitLabu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (7%)
     (4%)
     (0%)
     (9%)
     (21%)
     (4%)
     (5%)
     (3%)
     (10%)
     (50%)
    Celkem 365 hlasů
     Komentářů: 8, poslední včera 23:18
    Rozcestník

    Dotaz: Filtrování slov v souboru

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