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 03:33 | IT novinky

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

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

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 5
    6.2. 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 17
    6.2. 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 10
    6.2. 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    6.2. 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 26
    6.2. 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.2. 04:22 | Komunita

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 216. sraz, který proběhne v pátek 20. února od 18:00 v Red Hat Labu (místnost Q304) na Fakultě informačních technologií VUT v Brně na ulici Božetěchova 1/2. Tématem srazu bude komunitní komunikační síť MeshCore. Jindřich Skácel představí, co je to MeshCore, předvede nejrůznější klientské zařízení a ukáže, jak v praxi vypadá nasazení vlastního repeateru.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (25%)
     (3%)
     (5%)
     (2%)
     (12%)
     (29%)
    Celkem 797 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Filtrování slov v souboru

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