AWK-예쁜 인쇄

지금까지 우리는 AWK를 사용했습니다. printprintf표준 출력에 데이터를 표시하는 기능. 그러나 printf는 이전에 본 것보다 훨씬 강력합니다. 이 함수는 C 언어에서 빌려 왔으며 형식화 된 출력을 생성하는 데 매우 유용합니다. 아래는 printf 문의 구문입니다-

통사론

printf fmt, expr-list

위의 구문에서 fmt 형식 사양 및 상수의 문자열입니다. expr-list 형식 지정자에 해당하는 인수 목록입니다.

탈출 시퀀스

모든 문자열과 마찬가지로 형식에는 포함 된 이스케이프 시퀀스가 ​​포함될 수 있습니다. 다음은 AWK에서 지원하는 이스케이프 시퀀스입니다.

뉴 라인

다음 예제는 인쇄합니다. HelloWorld 개행 문자를 사용하여 별도의 줄에-

Example

[jerry]$ awk 'BEGIN { printf "Hello\nWorld\n" }'

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

Output

Hello
World

수평 탭

다음 예제는 수평 탭을 사용하여 다른 필드를 표시합니다.

Example

[jerry]$ awk 'BEGIN { printf "Sr No\tName\tSub\tMarks\n" }'

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

Output

Sr No   Name    Sub Marks

수직 탭

다음 예제는 각 필드 후에 수직 탭을 사용합니다-

Example

[jerry]$ awk 'BEGIN { printf "Sr No\vName\vSub\vMarks\n" }'

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

Output

Sr No
   Name
      Sub
         Marks

역행 키이

다음 예제는 마지막 필드를 제외한 모든 필드 뒤에 백 스페이스를 인쇄합니다. 처음 세 필드에서 마지막 숫자를 지 웁니다. 예를 들어Field 1 다음과 같이 표시됩니다. Field, 마지막 문자가 백 스페이스로 지워지기 때문입니다. 그러나 마지막 필드Field 4 있는 그대로 표시됩니다. \bField 4.

Example

[jerry]$ awk 'BEGIN { printf "Field 1\bField 2\bField 3\bField 4\n" }'

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

Output

Field Field Field Field 4

캐리지 리턴

다음 예에서는 모든 필드를 인쇄 한 후 Carriage Return 현재 인쇄 된 값 위에 다음 값을 인쇄합니다. 즉, 최종 출력에서는Field 4, 이전 모든 필드 위에 마지막으로 인쇄 된 것이기 때문입니다.

Example

[jerry]$ awk 'BEGIN { printf "Field 1\rField 2\rField 3\rField 4\n" }'

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

Output

Field 4

양식 공급

다음 예제에서는 각 필드를 인쇄 한 후 용지 공급을 사용합니다.

Example

[jerry]$ awk 'BEGIN { printf "Sr No\fName\fSub\fMarks\n" }'

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

Output

Sr No
   Name
      Sub
         Marks

형식 지정자

C 언어에서와 마찬가지로 AWK에도 형식 지정자가 있습니다. printf 문의 AWK 버전은 다음과 같은 변환 사양 형식을 허용합니다.

%씨

단일 문자를 인쇄합니다. 인수가 사용 된 경우%c숫자이며 문자로 처리되어 인쇄됩니다. 그렇지 않으면 인수는 문자열로 간주되고 해당 문자열의 첫 번째 문자 만 인쇄됩니다.

Example

[jerry]$ awk 'BEGIN { printf "ASCII value 65 = character %c\n", 65 }'

Output

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

ASCII value 65 = character A

% d 및 % i

십진수의 정수 부분 만 인쇄합니다.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %d\n", 80.66 }'

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

Output

Percentags = 80

% e 및 % E

[-] d.dddddde [+-] dd 형식의 부동 소수점 숫자를 인쇄합니다.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %E\n", 80.66 }'

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

Output

Percentags = 8.066000e+01

그만큼 %E 형식 사용 E e 대신.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %e\n", 80.66 }'

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

Output

Percentags = 8.066000E+01

%에프

[-] ddd.dddddd 형식의 부동 소수점 숫자를 인쇄합니다.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %f\n", 80.66 }'

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

Output

Percentags = 80.660000

% g 및 % G

중요하지 않은 0은 억제 된 상태에서 더 짧은 % e 또는 % f 변환을 사용합니다.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %g\n", 80.66 }'

Output

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

Percentags = 80.66

그만큼 %G 형식 사용 %E % e 대신.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %G\n", 80.66 }'

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

Output

Percentags = 80.66

%영형

부호없는 8 진수를 인쇄합니다.

Example

[jerry]$ awk 'BEGIN { printf "Octal representation of decimal number 10 = %o\n", 10}'

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

Output

Octal representation of decimal number 10 = 12

%유

부호없는 십진수를 인쇄합니다.

Example

[jerry]$ awk 'BEGIN { printf "Unsigned 10 = %u\n", 10 }'

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

Output

Unsigned 10 = 10

%에스

문자열을 인쇄합니다.

Example

[jerry]$ awk 'BEGIN { printf "Name = %s\n", "Sherlock Holmes" }'

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

Output

Name = Sherlock Holmes

% x 및 % X

부호없는 16 진수를 인쇄합니다. 그만큼%X 형식은 소문자 대신 대문자를 사용합니다.

Example

[jerry]$ awk 'BEGIN { 
   printf "Hexadecimal representation of decimal number 15 = %x\n", 15
}'

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

Output

Hexadecimal representation of decimal number 15 = f

이제 % X를 사용하고 결과를 관찰하십시오-

Example

[jerry]$ awk 'BEGIN { 
   printf "Hexadecimal representation of decimal number 15 = %X\n", 15
}'

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

Output

Hexadecimal representation of decimal number 15 = F

%%

단일 인쇄 % 문자 및 인수는 변환되지 않습니다.

Example

[jerry]$ awk 'BEGIN { printf "Percentags = %d%%\n", 80.66 }'

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

Output

Percentags = 80%

%가있는 선택적 매개 변수

% 다음과 같은 선택적 매개 변수를 사용할 수 있습니다.

필드는 width. 기본적으로 필드는 공백으로 채워지지만 0 플래그가 사용되면 0으로 채워집니다.

Example

[jerry]$ awk 'BEGIN { 
   num1 = 10; num2 = 20; printf "Num1 = %10d\nNum2 = %10d\n", num1, num2 
}'

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

Output

Num1 =         10
Num2 =         20

선행 0

선행 0은 플래그 역할을하며 출력이 공백 대신 0으로 채워 져야 함을 나타냅니다. 이 플래그는 필드가 인쇄 할 값보다 넓은 경우에만 효과가 있습니다. 다음 예제는 이것을 설명합니다-

Example

[jerry]$ awk 'BEGIN { 
   num1 = -10; num2 = 20; printf "Num1 = %05d\nNum2 = %05d\n", num1, num2 
}'

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

Output

Num1 = -0010
Num2 = 00020

왼쪽 정렬

표현식은 필드 내에서 왼쪽 정렬되어야합니다. 입력 문자열이 지정된 문자 수보다 적고 왼쪽 정렬을 원하면, 즉 오른쪽에 공백을 추가하여 % 바로 뒤와 숫자 앞에 빼기 기호 (-)를 사용하십시오.

다음 예에서 AWK 명령의 출력은 cat 명령으로 파이프되어 END OF LINE ($) 문자를 표시합니다.

Example

[jerry]$ awk 'BEGIN { num = 10; printf "Num = %-5d\n", num }' | cat -vte

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

Output

Num = 10   $

접두사 기호

값이 양수인 경우에도 항상 숫자 값 앞에 부호를 붙입니다.

Example

[jerry]$ awk 'BEGIN { 
   num1 = -10; num2 = 20; printf "Num1 = %+d\nNum2 = %+d\n", num1, num2 
}'

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

Output

Num1 = -10
Num2 = +20

해시시

% o의 경우 선행 0을 제공합니다. % x 및 % X의 경우 결과가 0이 아닌 경우에만 각각 선행 0x 또는 0X를 제공합니다. % e, % E, % f 및 % F의 경우 결과에는 항상 소수점이 포함됩니다. % g 및 % G의 경우 후행 0은 결과에서 제거되지 않습니다. 다음 예제는 이것을 설명합니다-

Example

[jerry]$ awk 'BEGIN { 
   printf "Octal representation = %#o\nHexadecimal representaion = %#X\n", 10, 10
}'

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

Output

Octal representation = 012
Hexadecimal representation = 0XA