Byla vydána beta verze openSUSE Leap 16. Ve výchozím nastavení s novým instalátorem Agama.
Devadesátková hra Brány Skeldalu prošla portací a je dostupná na platformě Steam. Vyšel i parádní blog autora o portaci na moderní systémy a platformy včetně Linuxu.
Lidi dělají divné věci. Například spouští Linux v Excelu. Využít je emulátor RISC-V mini-rv32ima sestavený jako knihovna DLL, která je volaná z makra VBA (Visual Basic for Applications).
Revolut nabídne neomezený mobilní tarif za 12,50 eur (312 Kč). Aktuálně startuje ve Velké Británii a Německu.
Společnost Amazon miliardáře Jeffa Bezose vypustila na oběžnou dráhu první várku družic svého projektu Kuiper, který má z vesmíru poskytovat vysokorychlostní internetové připojení po celém světě a snažit se konkurovat nyní dominantnímu Starlinku nejbohatšího muže planety Elona Muska.
Poslední aktualizací začal model GPT-4o uživatelům příliš podlézat. OpenAI jej tak vrátila k předchozí verzi.
Google Chrome 136 byl prohlášen za stabilní. Nejnovější stabilní verze 136.0.7103.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 8 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 4.5.0. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Byl vydán Mozilla Firefox 138.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 138 je již k dispozici také na Flathubu a Snapcraftu.
Šestnáctý ročník ne-konference jOpenSpace se koná 3. – 5. října 2025 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytvářejí všichni účastníci, se skládá z desetiminutových
… více »Předem upozorňuju, že se GNU stream editor (GNU sed, dále jen sed) teprve učím. Najdete zde pro mě důležité poznámky týkající se tohoto programu. Tyto poznámky pochopitelně může využít kdokoli. Poznámka: Vím, že na Internetu existuje spousta materiálů k sedu. Já tyto moje poznámky píšu hlavně, protože se mi mnou psaný text lépe pamatuje.
Sed slouží k filtraci/transformaci textu vstupního "proudu". Pod pojmem proud si představte (textový) soubor nebo rouru.
Nejčastěji se používá pro filtrování (transformaci) textu z roury. Tedy konstrukce typu program1 | sed...
Pokud chete použít sed, tak máte dvě možnosti:
sed SKRIPT VSTUPNI_SOUBORY...
sed VOLBY... [SKRIPT] [VSTUPNI_SOUBORY...]
sed program se skládá z jednoho nebo více sed příkazů, které vkládáme pomocí volby -e
(--expression
) nebo pomocí -f
(--file
). Tyto volby lze použít vícekrát, tedy lze vložit více příkazů. Sed považuje za příkaz i první argument následující za poslední volbou v případě, že se nepoužije ani volba -e, ani -f, resp. ani jejich dlouhé varianty. A všem příkazům dohromady se říká SKRIPT
.
[ADRESA1[,ADRESA2]]prikaz [ARGUMENTY]
Adresa může být vyjádřena následujicími způsoby:
\%REGULARNI_VYRAZ%
řádka musí odpovídat regulárnímu výrazu REGULARNI_VYRAZ. '%' můžete nahradit jedním znakem dle vašeho výběru, slouží jako oddělovač (pokud se má vyskytovat v regulárním výrazu, tak mu musí předcházet znak '\')./REGULARNI_VYRAZ/
řádka musí odpovídat regulárnímu vyrazu REGULARNI_VYRAZ. Pokud "REGULARNI_VYRAZ" má obsahovat znak '/', musí mu předcházet znak '\'.CISLO
odpovídá řádce s číslem CISLO.\%REGULARNI_VYRAZ%I
nebo /REGULARNI_VYRAZ/I
sed nebude rozlišovat velikost písmen, jinak viz výše.$
odpovídá poslední řádce posledního vstupního souboru.Rozšíření GNU:
PRVNI~KROK
sed vybere každou KROK-tou řádku, počínaje řádkem PRVNI.
ADRESA1,ADRESA2
takto můžete specifikovat "interval" -- jsou to všechny řádky mezi první řádkou odpovídající ADRESA1 a řádkou odpovídající ADRESA2 (včetně).
Ještě pár speciálních možností (jedná se o GNU rozšíření):
0,/REGULARNI_VYRAZ/
aby sed bral v potaz i první řádku, když řádky porovnává s REGULARNI_VYRAZ.ADRESA1,+C
Vybere řádek odpovídající ADRESA1 a C řádků za ním následujících.ADRESA1,~C
vybere řádek odpovídající ADRESA1 a řádky následující ADRESA1, dokud nenarazí ná řádek, jehož číslo je násobkem C.Vychytávkou je použití znaku '!'
ve specifikaci adresy. Pokud tento znak připojíme na konec specifikace adresy, potom budou vybrány pouze řádky, které neodpovídají specifikaci adresy (rozsahu). Tzn. je to taková negace.
s
(substitute)
Syntaxe: s/REGULARNI_VYRAZ/CIM_NAHRADIT/VOLBY
Poznámka: znak '/' může být nahrazen jiným znakem, např. s@REGULARNI_VYRAZ@CIM_NAHRADIT@VOLBY
(zaměnili jsme znak '/' za '@'. Pokud se znak '/' má vyskytnout v REGULARNI_VYRAZ nebo v CIM_NAHRADIT, musí mu předcházet znak '\'. Pokud znak '/' nahradíme jiným, postupuje se obdobně.
Jak název (substitute) napovídá, jedná se o příkaz sedu, který při každém průchodu modifikuje pattern space (viz výše) tak, že nahradí výraz odpovídající REGULARNI_VYRAZ za CIM_NAHRADIT.
Vychytávkou je, že v CIM_NAHRADIT se můžeme odkazovat pomocí \C
na C-tý zapamatovaný řetězec (C je přirozené číslo od 1 do 9), viz \(REGULARNI_VYRAZ\)
. V angličtině se tomu říká "back reference".
Další vychytávkou je to, že pokud umístíme do CIM_NAHRADIT znak '&'
, tak je odkazem na celý řetězec odpovídající REGULARNI_VYRAZ.
s
Příkaz s
může být následován těmito volbami:
g
aplikuj CIM_NAHRADIT na všechny výskyty řetězce, ne jenom na první.CISLO
nahraď pouze CISLO-tý řetězec odpovídajcí REGULARNI_VYRAZ.p
pokud došlo k nahrazení (substituci), vytiskne sed "nový" pattern space.w NAZEV-SOUBORU
pokud došlo k substituci, zapíše sed výsledek do NAZEV-SOUBORU. Lze použít dva speciální soubory (GNU rozšíření), a to /dev/stdout
(standardní výstup) a /dev/stderr
(standardní chybový výstup).
e
Pokud došlo k substituci, tak příkaz (program), který se nachází v pattern space je vykonán a pattern space je nahrazen jeho výstupem. Znak konce řádku je potlačen. Jedná se o rozšíření GNU.I
sed nebude rozlišovat velikost písmen. (GNU rozšíření)d
smaže obsah pattern space, okamžitě dojde k další obrátce cyklu.p
vytiskne obsah pattern space na standardní výstup. Používá se většinou s volbou '-n'
(ta potlačí vytisknutí pattern space na konci každého cyklu).q [NAVRATOVY-KOD]
sed bude ukončen s návratovým kódem NAVRATOVY-KOD bez zpracování jakýchkoli dalších příkazů nebo vstupu. Aktuální pattern space je vytisknut, pokud nebyla použita volba -n
. Schopnost navrátit návratový kód je GNU rozšíření.n
Pokud nebylo zakázáno automatické tisknutí pattern space, tak vytiskne pattern space. Potom nahradí pattern space další řádkou vstupu. Pokud už není žádný vstup, sed skončí bez zpracování dalších příkazů.{ PRIKAZY }
konstrukce k vytvoření skupiny příkazů. Příkazy se od sebe oddělují pomocí znaku ';'
(středník). Jeden středník musí být i před '}'
Takto jsem teoreticky vysvětlil pro mě nejdůležitější vlastnosti programu sed. Pokud vám chybí nějaké praktické příklady, tak zadejte do určitého vyhledávače např. "sed examples". Dále jsem vynechal výklad regulárních výrazů, protože je docela dobře znám. Případný zájemce ale najde na Internetu dostatek materiálů věnujících se regulárním výrazům.
Tiskni
Sdílej:
t [label]
- skočí na label
(nebo na konec, když label
chybí), pokud byla poslední substituce úspěšná. To se hodí když např. chci ze souboru ostranit nějaké řádky podle nějakého regexpu:
sed -n 's/...//;t;p;'
Abych se přiznal, tak zrovna tenhle příkaz mi není moc jasný. Teprve až ho pochopím, tak ho určitě přidám. Jinak díky.
sed -ne 's/...//;t;p;'
zrovna není štastný příklad, protože téhož asi raději dosáhneme čitelnějším: sed -e '/.../d'
. Ale jsou situace, kdy se hodí. b
je prostý skok, t
skok podmíněný (nahrazení s
proběhlo od začátku zpracování toho řádku). Do téhle kategorie patří i "hold space
" (g
, G
, h
, H
, x
) a možnost spojovat řádky na vstupu (N
).
Pravdou nicméně je, že když na tyto prostředky dojde, možná je na čase zvážit jiný nástroj (třeba awk
). sed
sice mnoho dokáže, ale složitější konstrukce se dle mého špatně čtou. Takže pro pobavení/potěšení stojí za to zkusit čistě sed
řešení problému, ale nemusí to být nutně řešení nejpraktičtější.
Čeho bych se raději vyvaroval (prostě je to nepěkná forma (a trochu plýtvání prostředky) jsou pekelné roury tak časté v mnoha skriptech: grep ... | awk ... | sed ... | grep -v ... | tr ... | ...
v libovolných sekvencích a opakováních. Všechny tyto úkony je lépe svěřit jednomu sed
nebo awk
skriptu.
Pokud máte rád knihy a hezky utříděné informace: <http://oreilly.com/catalog/9781565922259>.
Díky
Čeho bych se raději vyvaroval (prostě je to nepěkná forma (a trochu plýtvání prostředky) jsou pekelné roury tak časté v mnoha skriptech: grep ... | awk ... | sed ... | grep -v ... | tr ... | ... v libovolných sekvencích a opakováních. Všechny tyto úkony je lépe svěřit jednomu sed nebo awk skriptu.Z hlediska výkonu souhlas – ale co se týče přehlednosti, tak IMHO bude většinou vycházet líp, rozdělit to na víc menších srozumitelných částí, než jeden ultimátní skript. Jasně, dá se okomentovat, ale pokud to někdo píše na jednu řádku, tak mi přijdou přehlednější ty roury.
Hezká ukázka toho, jak může být sed užitečný (nastavení dynamického linkeru, který má gcc používat).
sed nepoužívá specifický druh regexpů, to spíš Perl má svoje rozšířeníTak tak, ale PCRE ma "hezci" syntaxi. Obvykle musim v sedu psat spoustu zpetnych lomitek v regexpech. Navic, kdyz uz umim perl, da se pouzit jako grep, sed, awk a neco navic (ikdyz awk toho umi taky dost).
Obvykle musim v sedu psat spoustu zpetnych lomitek v regexpech.
Protože z historických důvodů používá Basic RE. U GNU sedu to řeší přepínač -r
Děkuju za ocenění.
Jojo, já taky, ale poděl je, že zruší symlink a udělá z něj normální soubor. Řešením by mělo být --follow-symlinks.To bych neviděl jako problém :), ale proti --follow-symlinks nic nemám.
--follow-symlinks
pochopitelně neobsahuje a gnu nástroje mají být (afaik) nadmnožinou standardu, takže odtud takovéhle podivnosti. Je bohužel mnohem jednoduší přidat si vlastní extension než snažit se pohnout se standardem, ačkoli by to bylo v tomhle i mnoha dalších případech lepší.
To je imho kvůli standardu. Standard nic jako --follow-symlinks
pochopitelně neobsahuje a gnu nástroje mají být (afaik) nadmnožinou standardu,
Požadavek, aby implementace byla nadmnožinou standardu, nijak nebrání tomu, aby si přidala další přepínače, které POSIX nepožaduje - což je ostatně i samotný -i
(přesněji: všechny kromě -e
, -f
a -n
).
-i
je GNU rozšířením, nelze default vysvětlovat POSIXem, ale jen zpětnou kompatibilitou.
-i
není posix, no tak to je potom ještě blbější výmluva...
Je to docela problém, když máš třeba vhosty apache v /etc/apache2/sites-available a v sites-enabled pouze odkazy na ty povolený a pak se rozhodneš in-place editovat soubor přes symlink...Stačí nelézt, kam nemáš :).
Podle mě by --follow-symlinks měla být implicitní volba.Podle mě spíše ne. Mám radši, když nástroje dělají přesně to, co jim řeknu.
Ale důležitý je hlavně o tomto vědět, pak si na to člověk dá bacha.Tak.
Mám radši, když nástroje dělají přesně to, co jim řeknu.No právě – proto bych tady spíš čekal, že dojde k úpravě souboru (ne navíc ke smazání odkazu a uložení obyčejného souboru místo něj). Argument s kompatibilitou beru – ale logičtější by to bylo takhle.
o právě – proto bych tady spíš čekal, že dojde k úpravě souboru (ne navíc ke smazání odkazu a uložení obyčejného souboru místo něj). Argument s kompatibilitou beru – ale logičtější by to bylo takhle.Mno mě to přijde logičtější naopak. Protože kdyby sed tu volbu neměl, soubor bych si přejmenoval, dal ho sedu na vstupu a výstupu dal jeho původní jméno. Měl bych tedy stejný výsledek, jako má sed -i, proto mi to přijde přirozenější.
echo ahoj
), tak se taky zapíše skrze odkaz do cílového souboru – nepřepíše se ten odkaz obyčejným souborem.
Navíc sed
zachovává přístupová práva – taky proto bych čekal, že zachová symbolický odkaz.
Zajímavě se to chová taky při použití pevných odkazů:
$ echo 111 > soubor1.txt $ ln soubor1.txt soubor2.txt $ sed -i s/1/2/g soubor2.txt $ cat soubor2.txt 222 $ cat soubor1.txt 111Opět to původní soubor smaže a vytvoří úplně nový – místo aby to editoval „na místě“ v tom stejném souboru. Beru to prostě jako záludnost, na kterou je potřeba si dávat pozor, nějakou logiku v tom ale nevidím (kromě té snahy o kompatibilitu, což už jsem tu psal).
Navíc sed zachovává přístupová práva – taky proto bych čekal, že zachová symbolický odkaz.Navrácení přístupových práv je bezpečné, u toho následování linků si tak jistý nejsem.
Opět to původní soubor smaže a vytvoří úplně nový – místo aby to editoval „na místě“ v tom stejném souboru.On sed je proudový, takže by bylo dost zvláštní, kdyby něco editoval opravdu na místě.
Beru to prostě jako záludnost, na kterou je potřeba si dávat pozor, nějakou logiku v tom ale nevidím (kromě té snahy o kompatibilitu, což už jsem tu psal).Kompatibilita je pouze zachvávání určitého stavu, ne jeho vytváření :).
Jednou je to stream editor, tak je to stream editorTak tak, nikoli file editor
:p
Jojo, já taky, ale poděl je, že zruší symlink a udělá z něj normální soubor. Řešením by mělo být --follow-symlinks.Nebo použít
ed
. Poštvat ho na daný soubor k editaci a instrukce mu nakrmit na standardní vstup (třeba pomocí here documents) ;)
Díky