Portál AbcLinuxu, 9. května 2025 23:44
zdroj_dat | sed -e 's/^\s*//' -e 's/\s*$//'Shell není pomalý. Pomalé jsou jen zbytečné cykly v něm.
$FOO je jen nějaký mezičlánek, který plníš daty.ano, přesně tak
Odkud bereš data? Ze souboru nebo z výstupu nějakého procesu?Data beru z pole
sed -e 's/^\s*//' -e 's/\s*$//' <soubor.txtLeze to z tebe jak z chlupaté deky. Bílé znaky na začátku a na konci řádku bychom měli vyřešeny, co s těmi daty budeš dál dělat? Pokud je jen budeš chtít uložit do dalšího souboru, stačí na konec uvedeného řádku ještě přidat přesměrování
>druhy_soubor.txtPředpokládám však, že je asi budeš chtít nějak zpracovat. Co to bude?
Text /tmp/a Nějaký text /tmp/b Nějaký jiný text /tmp/ca potřebuji dostat soubor2 ve kterém bude
"Text-a" "/tmp/a" "Nějaký složka-b" "/tmp/b" "Nějaký jiný text-c" "/tmp/c"to je vše.. ;)
awk '!/jiný/ {printf($0)} /jiný/ {print($0)}' <data.txtkteré však nebude správné, protože jsi problém specifikoval příliš vágně. Navíc jsem tam neořezal bílé znaky na začátku a na konci, ale to asi v tuto chvíli tolik nevadí.
Text . /tmp/a Nějaký text ./tmp/b Nějaký jiný text . /tmp/c
foo ; bar #ŘÁDEK 1 foo ; bar #ŘÁDEK 2 foo ; bar #ŘÁDEK 3 foo ; bar #ŘÁDEK 4a výstup do uvozovek a vše na jeden řádek...
1 ; 5 88; 9 15 ; 1 87 ; 11 2 ; 1 89 ; 55 1 ;88soubor2 (výstup)
"1" "5" "88" "9" "15" "1" "87" "11" "2" "1" "89" "55" "1" "88"nebo klidně i takto, je to fuk
"1" "5" "88" "9" "15" "1" "87" "11" "2" "1" "89" "55" "1" "88"
sed 's/[ \t]*;[ \t]*/" "/g;s/^[ \t]*/"/;s/[ \t]*$/"/;'Pokud už to je konečně skutečné zadání, tak proč jsi to proboha nemohl napsat o třicet příspěvků dřív?
Pominu-li, že (1) mezera i tabulátor jsou také znaky, takže před prvním znakem ani za posledním žádné mezery ani tabulátory být nemohou, a (2) pět nul je pořád jen nula, tak to, o co vám nejspíš jde, lze např. pomocí
read FOO <<<"$FOO"
Pokud ty hodnoty ve skutečnosti čtete ze souboru, tak samozřejmě stačí rovnou
while read line; do ... done <file
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.