adsense_in_article_test


[bash: awk] 특정 위치(field)의 문자열에서 특정 길이 만큼 문자열 추출 (substr) 리눅스 bash script

awk에서도 expr의 substr 옵션과 같은 기능을 하는 함수가 존재한다. 이름도 substr로 같다. (expr의 substr 옵션에 대한 내용은 이전 게시물을 참고하자. 여기로)

substr 함수의 형식은 아래와 같다. 아래의 형식에서 문자열이 들어갈 자리에 $1, $2 등 위치(field) 변수를 지정해 주면 된다.

substr("문자열",[시작 위치],[길이])

간단한 예시를 보자. 문자열 "I'm a student"에서 세번째 단어(student)의 2번째 바이트부터 4바이트를 추출하고자 한다면 아래와 같이 될 것이다. substr 함수를 이용해서 3번째 단어의 2번째 바이트부터 4바이트를 추출하여 변수 result에 저장하고 print 명령으로 출력.

echo "I'm a student" | awk '{result=substr($3,2,4); print result}'
tude

변수를 사용하지 않고 추출 결과를 직접 print 명령의 인자로 넘겨도 된다. 아래의 예시를 보자.

echo "I'm a student" | awk '{print substr($3,2,4)}'
tude

형식이 일정하게 지정된 텍스트 파일에서 특정 항목을 골라 특정 문자열을 추출해야 할 경우 꽤 요긴하게 활용할 수 있다.

awk 활용에 대한 다른 게시물들은 여기로
 


핑백

덧글

댓글 입력 영역
* 비로그인 덧글의 IP 전체보기를 설정한 이글루입니다.


B-Side


adsense(w160_h600)2

통계 위젯 (화이트)

92848
5116
2103306

2019 대표이글루_IT

Google Analytics