Portál AbcLinuxu, 4. května 2025 15:37

Dotaz: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru

25.1.2016 12:01 Ladislav
Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
Přečteno: 425×
Odpovědět | Admin
Dobry den, niesom velmi v konzole zbehly ale riesim nasledujuci problem. Mam textove subory v ktorych je rozny pocet stlpcov. Minimalny pocet je 2. Tieto subory su v roznych podadresaroch. Potrebujem aby sa v kazdom subore v 2. stlpci ak prvy znak je 0 tento znak vymazal. Moj pokus je takyto:
#!/bin/bash

for i in $(find . -name *.txt); do
  awk '{gsub("^0","",$2); print $1,$2}' $i
done
avsak tento skript vypise iba opravene stlpce ale nezapise zmeny do suboru. Viete ma nejako usmernit spravnym smerom ?

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

Odpovědi

25.1.2016 12:22 NN
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
Odpovědět | | Sbalit | Link | Blokovat | Admin
#!/bin/bash

for i in $(find . -name *.txt); do
    sed -ri 's/\ 0(.*)$/\ \1/g' $i
done
Urizne prvni nulu za mezerou z prava, asi by to slo i elegantneji. Doporucuji nejprve otestovat(bez -i).
25.1.2016 12:33 Ladislav
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
Hmmm - no nevymaze to pociatocnu nulu z druheho stlpca :-( (skusal som bez -i)
Jendа avatar 25.1.2016 18:13 Jendа | skóre: 78 | blog: Jenda | JO70FB
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
sed -r 's/^([^ ]+)( +)0(.*)$/\1\2\3/g'
wamba avatar 25.1.2016 14:27 wamba | skóre: 38 | blog: wamba
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
Odpovědět | | Sbalit | Link | Blokovat | Admin
čím jsou odděleny sloupce, mezery?

třeba: find -name "*\.txt" |xargs perl -i -anE '$F[1] =~ s/^0//g;say "@F"'

opět pro zkoušku lze vynechat -i
This would have been so hard to fix when you don't know that there is in fact an easy fix.
25.1.2016 14:43 Ladislav
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
Ano medzera. Tento skript funguje, akurat zmensuje medzery, co by asi vadit nemalo, ale to sa dozviem az ked budem tieto TXT subory importovat na dalsie spracovanie. Da sa aj bez toho zmensovania medzier ? Dakujem kazdopadne.
wamba avatar 25.1.2016 15:32 wamba | skóre: 38 | blog: wamba
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
záleží jestli chcete ty mezery zachovat, pak třeba: find -name "*\.txt" |xargs perl -i -pE 's/^\s*\S+\s+\K0//;'.

nebo jen zvětšit mezery: find -name "*\.txt" |xargs perl -i -anE '$"="\t";$F[1] =~ s/^0//g;say "@F"'
This would have been so hard to fix when you don't know that there is in fact an easy fix.
25.1.2016 18:22 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
Odpovědět | | Sbalit | Link | Blokovat | Admin

Tvůj pokus má jednu vadu: nezachovává sloupce následující po druhém sloupci.

Tady je můj výstřel do tmy, který soubory už přímo edituje a zachovává všechny sloupce. Počítá s tabulátory jako oddělovači, ale klidně si tam lze dosadit místo \t mezery nebo skupiny znaků.

find . -name '*.txt' -exec sed -ir \
  's/(^[\t]*[^\t]+[\t]+)0(.*$)/\1\2/' '{}' +
Co když je v tom druhém sloupci pouze jedna samotná nula nebo více nul a nic nenulového za nimi? Pak by tam asi měla zůstat právě jedna nula, že ano. To bych udělal zhruba takto:
find . -name '*.txt' -exec sed -ir \
  's/(^[\t]*[^\t]+[\t]+)0+(([^\t0]|0).*$)/\1\2/' '{}' +

Tohle^^^ by mělo druhý sloupec nahradit takto:

0 -> 0
00 -> 0
000 -> 0
...
cosi -> cosi
0cosi -> cosi
00cosi -> cosi
...
25.1.2016 18:25 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru

Aha. Teď v diskusi výše vidím, že oddělovače jsou mezery. Takže:

find . -name '*.txt' -exec sed -ir \
  's/(^ *[^ ]+ +)0(.*$)/\1\2/' '{}' +
find . -name '*.txt' -exec sed -ir \
  's/(^ *[^ ]+ +)0+(([^ 0]|0).*$)/\1\2/' '{}' +

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.