Rumah >Tutorial sistem >LINUX >Cara menggunakan mod khas awk BEGIN dan END untuk pemprosesan

Cara menggunakan mod khas awk BEGIN dan END untuk pemprosesan

WBOY
WBOYke hadapan
2024-01-02 18:06:07903semak imbas

Dalam bahagian kelapan siri awk, kami memperkenalkan beberapa ciri perintah awk yang berkuasa, iaitu pembolehubah, ungkapan angka dan pengendali tugasan.

Dalam bahagian ini kita akan mempelajari lebih lanjut tentang fungsi awk, iaitu mod khas awk: MULA dan TAMAT.

Sambil kami maju dan menemui lebih banyak cara untuk membina operasi awk yang kompleks, kami akan membuktikan betapa hebatnya ciri khas awk ini.

Sebelum kita mula, mari kita semak pengenalan siri awk Ingat apabila kita memulakan siri ini, saya menegaskan bahawa sintaks umum arahan awk adalah seperti ini:

# awk 'script' filenames  

Dalam sintaks di atas, skrip awk mempunyai bentuk ini:

/pattern/ { actions } 

Anda biasanya akan mendapati bahawa corak dalam skrip (/corak) ialah ungkapan biasa, tetapi anda juga boleh menggunakan corak khas BENGIN dan END di sini. Oleh itu, kita juga boleh menulis arahan awk dalam bentuk berikut:

awk '
BEGIN { actions } 
/pattern/ { actions }
/pattern/ { actions }
……….
END { actions } 
' filenames  

Jika anda menggunakan mod khas dalam skrip awk: MULA dan TAMAT, berikut ialah maksud yang sepadan:

    Mod
  • MULA: bermakna awk akan melakukan tindakan yang dinyatakan dalam MULA serta-merta sebelum membaca sebarang baris input.
  • Mod
  • END: bermakna awk akan melaksanakan tindakan yang dinyatakan dalam END sebelum ia keluar secara rasmi.

Aliran pelaksanaan skrip arahan awk yang mengandungi mod khas ini adalah seperti berikut:

  1. Apabila corak BEGIN digunakan dalam skrip, semua tindakan dalam BEGIN akan dilaksanakan sebelum sebarang baris input dibaca.
  2. Kemudian, baris input dibaca dan dihuraikan ke dalam segmen yang berbeza.
  3. Seterusnya, setiap corak bukan khas yang ditentukan akan dibandingkan dan dipadankan dengan baris input Apabila perlawanan berjaya, tindakan yang sepadan dengan corak akan dilaksanakan. Ulangi langkah ini untuk semua corak yang anda tentukan.
  4. Seterusnya, ulangi langkah 2 dan 3 untuk semua baris input.
  5. Selepas semua baris input dibaca dan diproses, jika anda menentukan mod END, tindakan yang sepadan akan dilakukan.

Apabila anda menggunakan mod khas, untuk mendapatkan hasil terbaik daripada operasi awk, anda harus ingat perintah pelaksanaan di atas.

Untuk pemahaman yang mudah, mari kita gunakan contoh dalam Bahagian 8 untuk demonstrasi Contoh itu adalah mengenai senarai nama domain yang dimiliki oleh Tecmint dan disimpan dalam fail bernama domains.txt.

news.tecmint.com
tecmint.com
linuxsay.com
windows.tecmint.com
tecmint.com
news.tecmint.com
tecmint.com
linuxsay.com
tecmint.com
news.tecmint.com
tecmint.com
linuxsay.com
windows.tecmint.com
tecmint.com
$ cat ~/domains.txt

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

Lihat kandungan fail

Dalam contoh ini, kami ingin mengira bilangan kali nama domain tecmint.com muncul dalam fail domains.txt. Jadi, kami menulis skrip shell mudah untuk membantu kami menyelesaikan tugasan, yang menggunakan idea pembolehubah, ungkapan matematik dan pengendali tugasan Kandungan skrip adalah seperti berikut:

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

Sekarang mari kita gunakan dua mod istimewa ini dalam arahan awk skrip di atas seperti di bawah: MULA dan TAMAT :

Kita harus meletakkan skrip:

awk '/^tecmint.com/ { counter+=1 ; printf "%s/n", counter ; }' $file

Ditukar kepada:

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 内置变量的思想,所以,请继续保持关注。


Atas ialah kandungan terperinci Cara menggunakan mod khas awk BEGIN dan END untuk pemprosesan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:linuxprobe.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam