[완료] [질문] sed 정규식 치환 스크립트 작성중 어려움이 있습니다.
글쓴이: 자일자일 / 작성시간: 화, 2009/08/11 - 7:10오후
#cat db-linux xxx.xxx.xxx.92 blackdb2 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.98 ppkscome9 linux black dov9908 dov8281 xxx.xxx.xxx.96 ppkscome3 linux black dov9908 dov8281 xxx.xxx.xxx.97 1238lmc097 solaris sysadmin dov9908 dov8281 xxx.xxx.xxx.28 blackdbdev unix sysadmin dov9908 dov8281 xxx.xxx.xxx.28 blackwasdev unix sysadmin dov9908 dov8281 xxx.xxx.xxx.88 blackdb3 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.87 blackw9 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.88 blackw2 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.89 blackdb9 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.82 blackdb2 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.83 blackdb3 unix sysadmin dov9908 dov8281 xxx.xxx.xxx.88 blackdb8 unix sysadmin dov9908 dov8281
#cat def D:"Is Session"=00000001 S:"Protocol Name"=Telnet D:"Port"=00000017 D:"Send SGA"=00000001 D:"Send SGA All"=00000000 D:"Will LFLOW"=00000001 D:"Force Char Mode"=00000000 D:"Enable NAWS"=00000001 D:"Enable NTLM Authentication"=00000001 D:"Telnet Disable SSL Certificate Verification"=00000000 D:"Server Requires Bare CR"=00000000 S:"Hostname"=11.0.21.11
보시다시피 db-linux와 def라는 text 파일이있습니다.
db-linux 에서 각 필드를 라인마다 변수로 저장하여 파일로 출력하고
def라는 기본 서식파일에서
S:"Hostname"=11.0.21.11 라인을 이전에 읽어들인 ip변수로 치환하려고하려고
찾아보고 시도해봤는데 원하는대로 처리가 되지 않습니다.
무엇지 잘못 되었는지 고쳐 주실 수 있으시면 도와주세요.
감사합니다.
cat db-linux | \ while read ip host os id pass rootpass ; \ do cp def $ip\_$host\_$os\_$id\_$pass\_$rootpass.ini ; \ sed -r 's/^S:"Hostname"=.*/S:"Hostname"=/g' $ip\_$host\_$os\_$id\_$pass\_$rootpass.ini ; \ done
Forums:
cat db-linux | awk
cat db-linux | awk 'BEGIN{x="_";while((getline < "def")>0) def=def $0 "\n"}{file=$1x$2x$3x$4x$5x$6".ini";gsub("S:\"Hostname\"=.*","S:\"Hostname\"="$1,def);print def > file }END{}'
근데 질문이 좀....정확하지가 않으셧던거 같습니다
저도 공부했네요 :)
눈에 보이는 모든것은 보이지 않는 것들로 이루워져 있다.
Nobody reachs the Truth~*
눈에 보이는 모든것은 보이지 않는 것들로 이루워져 있다.
Nobody reachs the Truth~*
감사합니다.
위의 명령으로 정확히 원하는 결과 출력이 가능하네요.
제가 처음 작성했던 명령과는 또 다른 방법을 제시하여주셨습니다.
천천히 살펴보며 공부해봐야겠네요.
감사합니다.
추가 질문 드립니다.
알려주는 방법으로 하나의 파일내에 치환할 내용이 하나만 존재하면 원하는대로
출력되나, 동일한 라인이 둘 이상 존재할 경우에는 최초 1회 치환 후 다음 파일로
넘어가서 파일이 짤리게됩니다. 예를들면...
위와 같이 되어 있을때
알려주신 방법으로 실행하게 되면
cat db-linux | awk 'BEGIN{x="_";while((getline < "def")>0) def=def $0 "\n"}{file=$1x$2x$3x$4x$5x$6".ini";gsub("S:\"Hostname\"=.*","S:\"Hostname\"="$1,def);print def > file }END{}'
이렇게 치환 이후 파일을 닫아버리고 다음 파일로 넘어가네요.
이런 경우, 파일 치환을 하였더라도 문서의 끝까지 계속 치환 하도록 할 수 있는 방법이
있을까요 ?
감사합니다.
코드 안에 있는
코드 안에 있는 정규표현식 문제 입니다...
cat db-linux | awk 'BEGIN{x="_";while((getline < "def")>0) def=def $0 "\n"}{file=$1x$2x$3x$4x$5x$6".ini";gsub("S:\"Hostname\"=[^\n]*","S:\"Hostname\"="$1,def);print def > file }END{}'
와 같이 해보세요.
눈에 보이는 모든것은 보이지 않는 것들로 이루워져 있다.
Nobody reachs the Truth~*
눈에 보이는 모든것은 보이지 않는 것들로 이루워져 있다.
Nobody reachs the Truth~*
감사합니다.
gsub("S:\"Hostname\"=.*","S:\"Hostname\"="$1,def) 에서
아래와 같이 바뀌었네요.
gsub("S:\"Hostname\"=[^\n]*","S:\"Hostname\"="$1,def)
해결해 주셔서 감사합니다.
좋은 것 배웠습니다.
댓글 달기