검색을 해봤는데, 개행문자를 지우는 방법은 나와있습니다만,
"개행문자가 포함된 문자열"을 삭제하는 방법은 안나와 있더군요.
커맨드라인에서 바로 가능하다면, 최대한 그렇게 하고 싶습니다.......
예>
[~]$ echo 'TRUE,a b c,,,"""f k"' | sed 's/f\nk//g'
무슨 방법이 없을까요.
sed 'g/^$/d' 일겁니다.
고작 블로킹 하나, 고작 25점 중에 1점, 고작 부활동 "만약 그 순간이 온다면 그때가 네가 배구에 빠지는 순간이야"
그게 아니라요... 다음과 같이 "개행문자가 들어간 변수"의 문자열을 삭제하려고 하는거에요. 그런데 다음과 같이 sed에서 에러가 나오더라구요
[~]$ cat /tmp/q TRUE,a b c," abcdefg" [~]$ a='" abc' [~]$ cat /tmp/q | sed s/"$a"//g sed: -e expression #1, char 3: unterminated `s' command [~]$
제가 원하는 output은..
TRUE,a b c,defg"
아니면 혹시 fgrep 처럼 정규식 없이 "문자그대로" 편집할수 있는 옵션이 sed에 있나요?
제 기억으로는... 명령행으로 하면 안먹고.. 스크립트 파일을 만들어야 했던 것으로 기억합니다. 명령행으로 인자를 "등으로 감싸면 엔터를 넣을 수 있으니 되긴 하겠지만.. 아무튼 \n는 안먹는 걸로 기억합니다
sed -n '1h;2,$H;${g;s/\"\nabc//g;p}' q
혹은
a='\"\nabc'
sed -n '1h;2,$H;${g;s/'$a'//g;p}' q
감사합니다...
sed는 한 줄씩 읽어서 주어진 script를 실행하는 것을 반복하는 명령입니다. 따라서 multiline pattern을 찾는 것은 매우 어렵습니다.
주어진 script에서 '\n'이 안먹는게 아니라, 한 줄을 읽은 다음에 이 줄을 버퍼(pattern space)에 넣고 script를 실행하기 때문에 그렇습니다.
입력이 딱 두 줄이라면 아래 명령으로 됩니다만:
echo echo 'TRUE,a b c,,,"""f k"' | sed 'N;s/f\nk//g'
그게 아니라면 임시적으로 쓸 수 있는 다른 버퍼(hold space)와 함께 데이터를 준비하는 작업을 꽤 해야 합니다. 바로 위 익명사용자님이 말씀하신 것처럼요.
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html Korean Ver: http://cinsk.github.io/cfaqs/
개행문자를 딴문자로 바꿔서 처리를 하던가...
다른방법을 찾아서 해야겠네요 -_-...
답변 해주신 모든분들께 감사드립니다~
텍스트 포맷에 대한 자세한 정보
<code>
<blockcode>
<apache>
<applescript>
<autoconf>
<awk>
<bash>
<c>
<cpp>
<css>
<diff>
<drupal5>
<drupal6>
<gdb>
<html>
<html5>
<java>
<javascript>
<ldif>
<lua>
<make>
<mysql>
<perl>
<perl6>
<php>
<pgsql>
<proftpd>
<python>
<reg>
<spec>
<ruby>
<foo>
[foo]
sed 'g/^$/d' 일겁니다.
sed 'g/^$/d' 일겁니다.
고작 블로킹 하나, 고작 25점 중에 1점, 고작 부활동
"만약 그 순간이 온다면 그때가 네가 배구에 빠지는 순간이야"
그게 아니라요...다음과 같이 "개행문자가 들어간
그게 아니라요...
다음과 같이 "개행문자가 들어간 변수"의 문자열을 삭제하려고 하는거에요.
그런데 다음과 같이 sed에서 에러가 나오더라구요
제가 원하는 output은..
아니면 혹시 fgrep 처럼 정규식 없이
아니면 혹시 fgrep 처럼 정규식 없이 "문자그대로" 편집할수 있는 옵션이 sed에 있나요?
제 기억으로는... 명령행으로 하면 안먹고..
제 기억으로는... 명령행으로 하면 안먹고.. 스크립트 파일을 만들어야 했던 것으로 기억합니다.
명령행으로 인자를 "등으로 감싸면 엔터를 넣을 수 있으니 되긴 하겠지만..
아무튼 \n는 안먹는 걸로 기억합니다
이렇게 하면 어떨까요
sed -n '1h;2,$H;${g;s/\"\nabc//g;p}' q
혹은
a='\"\nabc'
sed -n '1h;2,$H;${g;s/'$a'//g;p}' q
감사합니다...
감사합니다...
sed는 한 줄씩 읽어서 주어진 script를
sed는 한 줄씩 읽어서 주어진 script를 실행하는 것을 반복하는 명령입니다.
따라서 multiline pattern을 찾는 것은 매우 어렵습니다.
주어진 script에서 '\n'이 안먹는게 아니라, 한 줄을 읽은 다음에 이 줄을 버퍼(pattern space)에 넣고
script를 실행하기 때문에 그렇습니다.
입력이 딱 두 줄이라면 아래 명령으로 됩니다만:
그게 아니라면 임시적으로 쓸 수 있는 다른 버퍼(hold space)와 함께 데이터를 준비하는 작업을 꽤 해야 합니다.
바로 위 익명사용자님이 말씀하신 것처럼요.
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
개행문자를 딴문자로 바꿔서 처리를
개행문자를 딴문자로 바꿔서 처리를 하던가...
다른방법을 찾아서 해야겠네요 -_-...
답변 해주신 모든분들께 감사드립니다~
댓글 달기