>시스템 튜토리얼 >리눅스 >처리를 위해 awk의 특수 모드 BEGIN 및 END를 사용하는 방법

처리를 위해 awk의 특수 모드 BEGIN 및 END를 사용하는 방법

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB앞으로
2024-01-02 18:06:07947검색

awk 시리즈의 여덟 번째 섹션에서는 변수, 숫자 표현식, 할당 연산자 등 강력한 awk 명령 기능을 소개했습니다.

이 섹션에서는 awk 기능, 즉 awk의 특수 모드인 BEGINEND에 대해 자세히 알아봅니다.

복잡한 awk 작업을 구축하는 더 많은 방법을 진행하고 발견하면서 awk의 이러한 특수 기능이 얼마나 강력한지 증명할 것입니다.

시작하기 전에 awk 시리즈의 소개를 살펴보겠습니다. 이 시리즈를 시작할 때 awk 명령의 일반적인 구문은 다음과 같다고 지적했습니다.

으아악

위 구문에서 awk 스크립트의 형식은 다음과 같습니다.

으아악

일반적으로 스크립트의 패턴(/pattern)은 정규 표현식이지만 여기서는 특수 패턴 BENGINEND을 사용할 수도 있습니다. 따라서 다음 형식으로 awk 명령을 작성할 수도 있습니다.

으아악

awk 스크립트에서 특수 모드인 BEGINEND을 사용하는 경우 해당 의미는 다음과 같습니다.

  • BEGIN 모드: awk가 입력 라인을 읽기 직전에 BEGIN에 지정된 작업을 수행함을 의미합니다.
  • END 모드: awk가 공식적으로 종료되기 전에 END에 지정된 작업을 실행함을 의미합니다.

이러한 특수 모드가 포함된 awk 명령 스크립트의 실행 흐름은 다음과 같습니다.

  1. 스크립트에서 BEGIN 패턴을 사용하면 입력 줄을 읽기 전에 BEGIN의 모든 작업이 실행됩니다.
  2. 그런 다음 입력 줄을 읽어서 여러 세그먼트로 구문 분석합니다.
  3. 다음으로, 지정된 각 비특수 패턴을 입력 라인과 비교하고 일치시킵니다. 일치에 성공하면 패턴에 해당하는 작업이 실행됩니다. 지정한 모든 패턴에 대해 이 단계를 반복합니다.
  4. 다음으로 모든 입력 행에 대해 2단계와 3단계를 반복합니다.
  5. 모든 입력 라인을 읽고 처리한 후 END 모드를 지정하면 해당 작업이 수행됩니다.

특수 모드를 사용할 때 awk 작업에서 최상의 결과를 얻으려면 위의 실행 순서를 기억해야 합니다.

이해를 돕기 위해 섹션 8의 예를 사용하여 설명하겠습니다. 해당 예는 Tecmint가 소유하고 domains.txt라는 파일에 저장된 도메인 이름 목록에 관한 것입니다.

으아악 으아악

如何使用 awk 的特殊模式 BEGIN 与 END

파일 내용 보기

이 예에서는 도메인 이름 tecmint.com이 domains.txt 파일에 나타나는 횟수를 계산하려고 합니다. 그래서 우리는 작업을 완료하는 데 도움이 되는 간단한 쉘 스크립트를 작성했는데, 이는 변수, 수학적 표현식 및 할당 연산자를 사용하여 스크립트 내용은 다음과 같습니다.

으아악

이제 아래와 같이 위 스크립트의 awk 명령에 이 두 가지 특수 모드를 적용해 보겠습니다. BEGINEND :

스크립트를 넣어야 합니다:

으아악

다음으로 변경됨:

awk ' BEGIN {  print "文件中出现 tecmint.com 的次数是:" ; }
/^tecmint.com/ {  counter+=1  ;  }
END {  printf "%s/n",  counter  ; } 
'  $file

在修改了 awk 命令之后,现在完整的 shell 脚本就像下面这样:

#!/bin/bash
for file in $@; do
if [ -f $file ] ; then
### 输出文件名
echo "File is: $file"
### 输出文件中 tecmint.com 出现的总次数
awk ' BEGIN {  print "文件中出现 tecmint.com 的次数是:" ; }
/^tecmint.com/ {  counter+=1  ;  }
END {  printf "%s/n",  counter  ; } 
'  $file
else
### 若输入不是文件,则输出错误信息
echo "$file 不是一个文件,请指定一个文件。" >&2 && exit 1
fi
done
### 成功执行后使用退出代码 0 终止脚本
exit 0

如何使用 awk 的特殊模式 BEGIN 与 END

awk 模式 BEGIN 和 END

当我们运行上面的脚本时,它会首先输出 domains.txt 文件的位置,然后执行 awk 命令脚本,该命令脚本中的特殊模式 BEGIN 将会在从文件读取任何行之前帮助我们输出这样的消息“文件中出现 tecmint.com 的次数是: ”。

接下来,我们的模式/^tecmint.com/ 会在每个输入行中进行比较,对应的动作{ counter+=1 ; } 会在每个匹配成功的行上执行,它会统计出 tecmint.com 在文件中出现的次数。

最终,END 模式将会输出域名 tecmint.com 在文件中出现的总次数。

$ ./script.sh ~/domains.txt 

如何使用 awk 的特殊模式 BEGIN 与 END

用于统计字符串出现次数的脚本

最后总结一下,我们在本节中演示了更多的 awk 功能,并学习了特殊模式 BEGINEND 的概念。

正如我之前所言,这些 awk 功能将会帮助我们构建出更复杂的文本过滤操作。第十节将会给出更多的 awk 功能,我们将会学习 awk 内置变量的思想,所以,请继续保持关注。


위 내용은 처리를 위해 awk의 특수 모드 BEGIN 및 END를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 linuxprobe.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제