awk 시리즈의 여덟 번째 섹션에서는 변수, 숫자 표현식, 할당 연산자 등 강력한 awk 명령 기능을 소개했습니다.
이 섹션에서는 awk 기능, 즉 awk의 특수 모드인 BEGIN 및 END에 대해 자세히 알아봅니다.
복잡한 awk 작업을 구축하는 더 많은 방법을 진행하고 발견하면서 awk의 이러한 특수 기능이 얼마나 강력한지 증명할 것입니다.
시작하기 전에 awk 시리즈의 소개를 살펴보겠습니다. 이 시리즈를 시작할 때 awk 명령의 일반적인 구문은 다음과 같다고 지적했습니다.
으아악위 구문에서 awk 스크립트의 형식은 다음과 같습니다.
으아악일반적으로 스크립트의 패턴(/pattern)은 정규 표현식이지만 여기서는 특수 패턴 BENGIN 및 END을 사용할 수도 있습니다. 따라서 다음 형식으로 awk 명령을 작성할 수도 있습니다.
으아악awk 스크립트에서 특수 모드인 BEGIN 및 END을 사용하는 경우 해당 의미는 다음과 같습니다.
이러한 특수 모드가 포함된 awk 명령 스크립트의 실행 흐름은 다음과 같습니다.
특수 모드를 사용할 때 awk 작업에서 최상의 결과를 얻으려면 위의 실행 순서를 기억해야 합니다.
이해를 돕기 위해 섹션 8의 예를 사용하여 설명하겠습니다. 해당 예는 Tecmint가 소유하고 domains.txt라는 파일에 저장된 도메인 이름 목록에 관한 것입니다.
으아악 으아악 파일 내용 보기이 예에서는 도메인 이름 tecmint.com이 domains.txt 파일에 나타나는 횟수를 계산하려고 합니다. 그래서 우리는 작업을 완료하는 데 도움이 되는 간단한 쉘 스크립트를 작성했는데, 이는 변수, 수학적 표현식 및 할당 연산자를 사용하여 스크립트 내용은 다음과 같습니다.
으아악이제 아래와 같이 위 스크립트의 awk 명령에 이 두 가지 특수 모드를 적용해 보겠습니다. BEGIN 및 END :
스크립트를 넣어야 합니다:
으아악다음으로 변경됨:
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 0awk 模式 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 功能将会帮助我们构建出更复杂的文本过滤操作。第十节将会给出更多的 awk 功能,我们将会学习 awk 内置变量的思想,所以,请继续保持关注。
위 내용은 처리를 위해 awk의 특수 모드 BEGIN 및 END를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!