[완료] [질문] sed 정규식 치환 스크립트 작성중 어려움이 있습니다.

자일자일의 이미지

#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
inniskun의 이미지

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회 치환 후 다음 파일로
넘어가서 파일이 짤리게됩니다. 예를들면...

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
S:"Hostname"=11.0.21.11
S:"Hostname"=11.0.21.11
S:"Hostname"=11.0.21.11
S:"Hostname"=11.0.21.11
asbc
dodofo
dfdaf

위와 같이 되어 있을때

알려주신 방법으로 실행하게 되면
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{}'

-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.28_blackdbdev_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.28_blackwasdev_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.82_blackdb2_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.83_blackdb3_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.87_blackw9_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.88_blackdb3_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.88_blackdb8_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.88_blackw2_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.89_blackdb9_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.92_blackdb2_unix_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.96_ppkscome3_linux_black_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.97_1238lmc097_solaris_sysadmin_dov9908_dov8281.ini
-rw-rw-r-- 1 jy jy  355 2009-08-12 09:14 xxx.xxx.xxx.98_ppkscome9_linux_black_dov9908_dov8281.ini

$cat xxx.xxx.xxx.88_blackw2_unix_sysadmin_dov9908_dov8281.ini
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"=xxx.xxx.xxx.88
$

이렇게 치환 이후 파일을 닫아버리고 다음 파일로 넘어가네요.

이런 경우, 파일 치환을 하였더라도 문서의 끝까지 계속 치환 하도록 할 수 있는 방법이
있을까요 ?

감사합니다.

inniskun의 이미지

코드 안에 있는 정규표현식 문제 입니다...

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)

해결해 주셔서 감사합니다.
좋은 것 배웠습니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <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].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <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].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <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].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <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].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.