전에는 awk로 표준출력을 가지고 놀았었죠...

이번엔 바로 파일로 가자구요.^^

흠..awk를 테스트 하는 프로그램을 만들어 보아요..

우선 아래 코드를 보시고 시작을 할까요?

File 1. 22 (DATA FILE)

길이|1|290
태호|0|100
성철|0|50


File 2. awktest

awk -F '|' '
    BEGIN{
                print "==============================";
                print "이름  |  바보여부 |  IQ";
            }
            {
                if ($2 == "1")
                {
                    BaboYn="Y";
                }
                else
                {
                    BaboYn="N";
                }

                print $1 "  |     " BaboYn "     |  " $3;

            }
    END  {
                print "==============================";
            }' 22


# Output
==============================
이름  |  바보여부 |  IQ
길이  |     Y     |  290
태호  |     N     |  100
성철  |     N     |  50
==============================


위처럼 저는 awk를 이용해서 22파일을 읽어서 제어하는 프로그램을 만들어 보았습니다.

awk에서 -F 가 구분자라는것은 전에 말씀 드렸죠?..^^

그리고 BEGIN은 파일을 열기전에 실행할 코드 입니다.

단순히 헤더를 만든다던가 할때 쓰면 좋겠죠..

아니면 연산을 할때 써도 좋구요..

좀 코드를 깔끔하게 하고자 하신다면..

사용하실 변수를 BEGIN에서 선언해도 좋습니다.^^


그리고 아무것도 없이 {}로 되어 있는 녀석들 있죠?

이녀석들이 파일을 한줄씩 읽어서 안의 코드를 실행 시켜주는 역할을 합니다.

파일이 1000000줄이라면 1000000번 실행 되겟죠??..^^

우선 $2 는 구분자 기준으로 두번째에 있는 녀석이고요..

이 녀석 값이 1 이면 BaboYn이라는 변수에 "Y"를 넣어줍니다..
아니면 BaboYn변수에는 "N"을 넣어 주고요..

그다음에는 print를 통해서 출력을 합니다..

이렇게 데이터 파일의 라인수 만큼 로직을 실행한뒤에 END 문을 탑니다..

END문은 프로그램이 종료하기전 한번만 타는 것이죠

저는 END에서 그냥 "==="를 출력 해 주었습니다.

모...Sum이 필요하다면 END부분에서 SUM한 값을 출력해줄 수도 있겠죠..

으흐흐...아주 쉽죠?

날로 먹는것 같다고요?;;

죄송합니다...삐질;;;

다음 이시간이 또 있을겁니다..

무언가 준비하겠죠.^^

으흐흐..부족한것 있으면 댓글이나 트랙백 주시면 감사하겠습니다.

댓글은 항상 열려 있으니..

부족하거나 요청 하실것이 있으면 말씀 주세요.^^..
신고

+ Recent posts

티스토리 툴바