AWK-내장 변수

AWK는 몇 가지 기본 제공 변수를 제공합니다. AWK 스크립트를 작성하는 동안 중요한 역할을합니다. 이 장에서는 내장 변수의 사용법을 보여줍니다.

표준 AWK 변수

표준 AWK 변수는 아래에서 설명합니다.

ARGC

명령 줄에 제공된 인수의 수를 의미합니다.

Example

[jerry]$ awk 'BEGIN {print "Arguments =", ARGC}' One Two Three Four

이 코드를 실행하면 다음 결과가 나타납니다.

Output

Arguments = 5

그러나 4 개의 인수 만 전달했는데 AWK가 5를 표시하는 이유는 무엇입니까? 의심을 없애기 위해 다음 예제를 확인하십시오.

ARGV

명령 줄 인수를 저장하는 배열입니다. 배열의 유효한 인덱스 범위는 0에서 ARGC-1까지입니다.

Example

[jerry]$ awk 'BEGIN { 
   for (i = 0; i < ARGC - 1; ++i) { 
      printf "ARGV[%d] = %s\n", i, ARGV[i] 
   } 
}' one two three four

이 코드를 실행하면 다음 결과가 나타납니다.

Output

ARGV[0] = awk
ARGV[1] = one
ARGV[2] = two
ARGV[3] = three

CONVFMT

숫자의 변환 형식을 나타냅니다. 기본값은%.6g.

Example

[jerry]$ awk 'BEGIN { print "Conversion Format =", CONVFMT }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

Conversion Format = %.6g

환경

환경 변수의 연관 배열입니다.

Example

[jerry]$ awk 'BEGIN { print ENVIRON["USER"] }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

jerry

다른 환경 변수의 이름을 찾으려면 env 명령.

파일 이름

현재 파일 이름을 나타냅니다.

Example

[jerry]$ awk 'END {print FILENAME}' marks.txt

이 코드를 실행하면 다음 결과가 나타납니다.

Output

marks.txt

FILENAME은 BEGIN 블록에 정의되어 있지 않습니다.

FS

(입력) 필드 구분 기호를 나타내며 기본값은 공백입니다. 다음을 사용하여 변경할 수도 있습니다.-F 명령 줄 옵션.

Example

[jerry]$ awk 'BEGIN {print "FS = " FS}' | cat -vte

이 코드를 실행하면 다음 결과가 나타납니다.

Output

FS =  $

NF

현재 레코드의 필드 수를 나타냅니다. 예를 들어 다음 예제에서는 필드가 두 개 이상 포함 된 행만 인쇄합니다.

Example

[jerry]$ echo -e "One Two\nOne Two Three\nOne Two Three Four" | awk 'NF > 2'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

One Two Three
One Two Three Four

NR

현재 레코드의 번호를 나타냅니다. 예를 들어, 다음 예제는 현재 레코드 번호가 3보다 작은 경우 레코드를 인쇄합니다.

Example

[jerry]$ echo -e "One Two\nOne Two Three\nOne Two Three Four" | awk 'NR < 3'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

One Two
One Two Three

FNR

NR과 유사하지만 현재 파일에 상대적입니다. AWK가 여러 파일에서 작동 할 때 유용합니다. FNR 값이 새 파일로 재설정됩니다.

OFMT

출력 형식 번호를 나타내며 기본값은 다음과 같습니다. %.6g.

Example

[jerry]$ awk 'BEGIN {print "OFMT = " OFMT}'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

OFMT = %.6g

OFS

출력 필드 구분 기호를 나타내며 기본값은 공백입니다.

Example

[jerry]$ awk 'BEGIN {print "OFS = " OFS}' | cat -vte

이 코드를 실행하면 다음 결과가 나타납니다.

Output

OFS =  $

ORS

출력 레코드 구분 기호를 나타내며 기본값은 개행입니다.

Example

[jerry]$ awk 'BEGIN {print "ORS = " ORS}' | cat -vte

위의 코드를 실행하면 다음과 같은 결과가 나타납니다.

Output

ORS = $
$

강도

일치하는 문자열의 길이를 나타냅니다. match함수. AWK의 일치 함수는 입력 문자열에서 주어진 문자열을 검색합니다.

Example

[jerry]$ awk 'BEGIN { if (match("One Two Three", "re")) { print RLENGTH } }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

2

RS

(입력) 레코드 분리자를 나타내며 기본값은 개행입니다.

Example

[jerry]$ awk 'BEGIN {print "RS = " RS}' | cat -vte

이 코드를 실행하면 다음 결과가 나타납니다.

Output

RS = $
$

RSTART

일치하는 문자열의 첫 번째 위치를 나타냅니다. match 함수.

Example

[jerry]$ awk 'BEGIN { if (match("One Two Three", "Thre")) { print RSTART } }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

9

구독

배열 첨자의 구분 문자를 나타내며 기본값은 다음과 같습니다. \034.

Example

[jerry]$ awk 'BEGIN { print "SUBSEP = " SUBSEP }' | cat -vte

이 코드를 실행하면 다음 결과가 나타납니다.

Output

SUBSEP = ^\$

$ 0

전체 입력 레코드를 나타냅니다.

Example

[jerry]$ awk '{print $0}' marks.txt

이 코드를 실행하면 다음 결과가 나타납니다.

Output

1) Amit     Physics   80
2) Rahul    Maths     90
3) Shyam    Biology   87
4) Kedar    English   85
5) Hari     History   89

$ n

필드가 FS로 구분되는 현재 레코드 의 n 번째 필드를 나타냅니다 .

Example

[jerry]$ awk '{print $3 "\t" $4}' marks.txt

이 코드를 실행하면 다음 결과가 나타납니다.

Output

Physics   80
Maths     90
Biology   87
English   85
History   89

GNU AWK 특정 변수

GNU AWK 특정 변수는 다음과 같습니다.

ARGIND

현재 처리중인 파일의 ARGV 인덱스를 나타냅니다.

Example

[jerry]$ awk '{ 
   print "ARGIND   = ", ARGIND; print "Filename = ", ARGV[ARGIND] 
}' junk1 junk2 junk3

이 코드를 실행하면 다음 결과가 나타납니다.

Output

ARGIND   =  1
Filename =  junk1
ARGIND   =  2
Filename =  junk2
ARGIND   =  3
Filename =  junk3

BINMODE

비 POSIX 시스템의 모든 파일 I / O에 대해 2 진 모드를 지정하는 데 사용됩니다. 1, 2 또는 3의 숫자 값은 입력 파일, 출력 파일 또는 모든 파일이 각각 2 진 I / O를 사용해야 함을 지정합니다. 문자열 값r 또는 w입력 파일 또는 출력 파일이 각각 이진 I / O를 사용해야 함을 지정합니다. 문자열 값rw 또는 wr 모든 파일이 이진 I / O를 사용해야 함을 지정합니다.

에르 노

문자열은 리디렉션이 실패 할 때 오류를 나타냅니다. getline 또는 close 호출이 실패합니다.

Example

[jerry]$ awk 'BEGIN { ret = getline < "junk.txt"; if (ret == -1) print "Error:", ERRNO }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

Error: No such file or directory

FIELDWIDTHS

필드 너비 변수의 공백으로 구분 된 목록이 설정되고 GAWK는 FS 변수의 값을 필드 구분 기호로 사용하는 대신 입력을 고정 너비의 필드로 구문 분석합니다.

IGNORECASE

이 변수가 설정되면 GAWK는 대소 문자를 구분하지 않습니다. 다음 예제는 이것을 보여줍니다-

Example

[jerry]$ awk 'BEGIN{IGNORECASE = 1} /amit/' marks.txt

이 코드를 실행하면 다음 결과가 나타납니다.

Output

1) Amit  Physics   80

린트

그것은 동적 제어를 제공합니다 --lintGAWK 프로그램의 옵션. 이 변수가 설정되면 GAWK는 린트 경고를 인쇄합니다. fatal 문자열 값을 할당하면 Lint 경고는 다음과 같이 치명적인 오류가됩니다.--lint=fatal.

Example

[jerry]$ awk 'BEGIN {LINT = 1; a}'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

awk: cmd. line:1: warning: reference to uninitialized variable `a'
awk: cmd. line:1: warning: statement has no effect

프로세스 정보

이것은 실제 및 유효 UID 번호, 프로세스 ID 번호 등과 같은 프로세스에 대한 정보를 포함하는 연관 배열입니다.

Example

[jerry]$ awk 'BEGIN { print PROCINFO["pid"] }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

4316

TEXTDOMAIN

AWK 프로그램의 텍스트 도메인을 나타냅니다. 프로그램의 문자열에 대한 지역화 된 번역을 찾는 데 사용됩니다.

Example

[jerry]$ awk 'BEGIN { print TEXTDOMAIN }'

이 코드를 실행하면 다음 결과가 나타납니다.

Output

messages

위의 출력은 다음과 같은 이유로 영어 텍스트를 보여줍니다. en_IN 장소