Portál AbcLinuxu, 12. května 2025 01:09

Dotaz: sed - smazani newline

6.4.2009 15:29 Elijen
sed - smazani newline
Přečteno: 1849×
Odpovědět | Admin

Zdravim,

poradil byste nekdo prosim jak pomoci sedu smazu vsechny nove radky? Vim ze by to slo udelat pomoci tr mnohem jednoduseji, ale chtel bych vedet jak na to v sedu.

Teprve dneska jsem se dozvedel ze existuje neco jako hold space, ale vubec me to neposloucha ;-)

Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

Tarmaq avatar 6.4.2009 15:54 Tarmaq | skóre: 39
Rozbalit Rozbalit vše Re: sed - smazani newline
Odpovědět | | Sbalit | Link | Blokovat | Admin
Zkus tohle:
sed '/^$/d'
Don't panic!
6.4.2009 15:58 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
Rozbalit Rozbalit vše Re: sed - smazani newline
Odpovědět | | Sbalit | Link | Blokovat | Admin
Třeba takhle (nakrmte přes STDIN nebo ze souboru argumentem příkazové řádky):
sed -ne '1{h;n;}
H
${g;s#\n# #g;p;}'
http://prirucka.ujc.cas.cz/?ref=785&id=790.
6.4.2009 16:00 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
Rozbalit Rozbalit vše Re: sed - smazani newline
Aha, koukám na příspěvek výše, a koukám, že má nejistota, jestli to správně chápu, byla na místě. Chcete odstranit znak "nový řádek" nebo jenom odstranit prázdné řádky? Nebo ještě něco jiného?
Tarmaq avatar 6.4.2009 16:29 Tarmaq | skóre: 39
Rozbalit Rozbalit vše Re: sed - smazani newline
taky jsem si nebyl uplne jisty z dotazu autora, ale myslim ze chce odstranit prazdne radky ;]
nejjistejsi ale bude, kdyz nam odpovi sam
Don't panic!
6.4.2009 16:34 l4m4
Rozbalit Rozbalit vše Re: sed - smazani newline
Nebo odstranit řádky, které nejsou staré...

IMO odstranění řádků vyhovujících nějaké podmínce není úkol, k nemuž by člověka typicky napadlo použít hold space, takže bych se přikláněl k odstraňování \n. I když kdo ví...
6.4.2009 17:30 Elijen
Rozbalit Rozbalit vše Re: sed - smazani newline

Omlouvam se za spatnou formulaci dotazu :-)

To co chci je zkratka vymazat vsechny vyskyty "\n" ... tedy by mela vzniknout jedna dlouha radka, kterou dale budu parsovat.

sed -ne '1{h;n;}
H
${g;s#\n# #g;p;}'

Zda se, ze toto pracuje, jak bych chtel, dekuji mnohokrat. Mohl byste prosim jeste vysvetlit jak to funguje? Neni mi jasne kdy a proc nastava okamzik ze mohu pouzit s/\n/ /g, ktery bezne nefunguje.

6.4.2009 17:51 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
Rozbalit Rozbalit vše Re: sed - smazani newline
První řádek se provede pouze pro první řádek vstupu: vloží jej do "hold spacu" a skočí přeskočí na zpracovávání dalšího záznamu. Druhý řádek pak přidá každý další řádek do "hold spacu". Tahle konstrukce (místo prostého H bez rozlišení řádku je tam proto, abyste nezačal celý "hold space" prázdným řádkem.

Třetí řádek se provede až u poslední položky na vstupu. Po přidání řádku do "hold spacu" si pomocí g vložíte vše, co jste si odložil do aktuálně zpracovávaného prostoru, nahradíte ty nové řádky (s) a výsledek vytisknete (p).

Jde to i bez "hold space" použitím příkazů pro práci s více řádky, ale když už jste je zmiňoval, tak proč je neukázat v praxi. ;)
6.4.2009 19:28 Elijen
Rozbalit Rozbalit vše Re: sed - smazani newline
Chápu-li to správně, tak důvod, proč to funguje je ten, že když z hold space zkopíruji obsah do pattern space, tak sed zpracovává celý obsah pattern space jako by to byl jeden řádek?
6.4.2009 23:25 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
Rozbalit Rozbalit vše Re: sed - smazani newline
Ano, po příkazu g/x (a svým způsobem G) zpracováváte to, co bylo do teď uloženo v "hold space". Když to bylo více naakumulovaných řádků, tak je máte na talíři všechny včetně "new line" mezi nimi.
7.4.2009 10:46 l4m4
Rozbalit Rozbalit vše Re: sed - smazani newline
K tomu ovšem není třeba používat hold space, viz moje řešení: prostě se všechno naráz načte do pattern space, odstraní \n a vypíše.
8.4.2009 18:06 Elijen
Rozbalit Rozbalit vše Re: sed - smazani newline
Nicméně Vaše řešení mi nefunguje ;) ... výstup vypadá nepozměněn.
9.4.2009 10:51 l4m4
Rozbalit Rozbalit vše Re: sed - smazani newline
$ sed --version
GNU sed version 4.1.5
Copyright (C) 2003 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE,
to the extent permitted by law.
$ sed --version | sed ':a ${s/\n//g;t;};N;ba'
GNU sed version 4.1.5Copyright (C) 2003 Free Software Foundation, Inc.This is free software; see the source for copying conditions.  There is NOwarranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE,to the extent permitted by law.
6.4.2009 16:27 l4m4
Rozbalit Rozbalit vše Re: sed - smazani newline
Odpovědět | | Sbalit | Link | Blokovat | Admin
sed ':a ${s/\n//g;t;};N;ba'

I když toto tedy vypíše \n úplně na konci všeho...
8.4.2009 21:00 MARION | Zlín
Rozbalit Rozbalit vše Re: sed - smazani newline
Odpovědět | | Sbalit | Link | Blokovat | Admin
sed '/^$/d' soubor vymaze vsechny prazdne radky. Poradi nekdo jak zaridit, aby vsechny se po sobe jdouci prazdne radky zredukovaly na jeden? Tzn kazda dira mezi radky by se "smrskla" na jediny prazdny radek.
9.4.2009 09:54 deadmail
Rozbalit Rozbalit vše Re: sed - smazani newline
napriklad cez awk ;-)
awk '/^$/{while (match($0,/^$/) && getline);print ""};/./{print}' 
9.4.2009 10:03 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
Rozbalit Rozbalit vše Re: sed - smazani newline
Stačí trochu přiohnout řešení uvedené výše - místo nahrazení konce řádku nahradíme po sobě jdoucí konce řádků jedním:
sed -ne '1{h;n;}
H
${g;s#\n\n\n*#\n\n#g;p;}'
I am always ready to learn although I do not always like to be taught. (W. Churchill)
9.4.2009 12:43 deadmail
Rozbalit Rozbalit vše Re: sed - smazani newline
vysledky uvedenych prikazov awk a sed sa lisia ak je viac prazdnych riadkov na zaciatku a/alebo na konci vstupu. Awk vypise aj tam iba jediny prazdny riadok :-) .
12.4.2009 16:38 Elijen
Rozbalit Rozbalit vše Re: sed - smazani newline
Odpovědět | | Sbalit | Link | Blokovat | Admin

Děkuji všem za rady, už to chápu ... nicméně mám daší problém ;) Na vstupu mám text, jež je (logicky) rozdělen do určitých bloků (každý blok končí řádkem na němž je pouze "."). A já bych chtěl, pomocí sedu tyto bloky vypsat odzadu - poslední, předposlední, ... (pořadí řádků v blocích se nemění). Nevíte někdo prosím, kde je chyba?

#!/usr/bin/sed -f
N
/^\.$/{x;H}
${x;p}

Skript spouštím s parametrem -n ... na výstupu se nic neobjěví ;(


Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.