쉘 스크립트로(bash) 특정한 문자열 뽑아내는 방법이 궁금합니다.
글쓴이: rajakym / 작성시간: 수, 2014/04/23 - 4:27오후
test.txt 란 파일이 있습니다.
이 파일엔
http://stst:8084/sgsg/injjg/45345 sgfsdagahah
sdfsdg http://stst:8084/sgsg/injjg/45345
"
http://stst:8084/sgsg/injjg/45345 http://stst:8084/sgsg/injjg/45345
"http://stst:8084/sgsg/injjg/45345
"
dsfdsfsgii
http://stst:8084/sgsg/injjg/45345
이런 형식으로 url 과 특수문자 그리고 공백이 같이 있는 파일 입니다.
이 파일에서
http:// 로 시작되는 url 들만을 추출하는 스크립트를 만들 수 있을까요?
#!/bin/bash while read line do echo $line if [ $line == "" ] then echo $line >> result.txt fi done < test.txt
그냥 공백행은 스킵하는 정도로 밖에
못 짜겠습니다.
awk 나 sed 를 쓰라고 하시는데
사실 awk 나 sed 의 개념을 모르겠습니다.
그리고 done < test.txt
이 행도 이해가 잘 되지 않습니다.
애초에 while read line 이 행에서
line 이 아무것도 없기 때문에( 입력값이 없어서)
바로 끝나야 하는것 아닌가요?
쉘 스크립트는 처음이라
done < test.txt 이 구문이 납득이 가지 않습니다.
Forums:
음 ..
되면 한다! / feel no sorrow, feel no pain, feel no hurt, there's nothing gained.. only love will then remain.. 『 Mizz 』
감사합니다.
파일 내용중에 http://stata:8935/sgagai/asgag" 이런식으로 끝에 쌍따음표가 있느느 경우
출력이
http://stata:8935/sgagai/asgag
http://stata:8935/sgagai/asgag"
http://stata:8935/sgagai/asgag"
이런 식으로 끝에 " 문자가 붙어서 난감했는데요
cat test.txt | grep -Po 'http://[^"]+' | grep -Po 'http://[^[[:space:]]+'
이런식으로 두번써서 해결 하였습니다.
답변주셔서 감사합니다!
댓글 달기