多くのテキストプロセッサまたはLinux / UNIXシステムでは、テキストエディタが含まれているのgrep、sedのとawkのテキスト処理ツールは、多くの場合、シェルプログラミングで使用されているので、と呼ばれる人々の広い範囲の業界「シェルプログラミング三銃士"。
grepコマンドツール
日常生活の中でgrepコマンドツールは、頻繁に使用される、言っても過言でありません、あなたは友人が理解していない持っている場合は、ボーエンを参照してください。シェルスクリプトは、詳細を使用する正規表現、関連grepコマンドを詳細に説明されパラメータと使用、
sedコマンドツール
sedのテキストを読むことができる強力かつシンプルなテキスト分析と変換ツールで、編集テキストの指定された条件に応じて、最終出力のすべての行は、特定の行、出力処理を生きるsedのは、対話の状況が存在しない場合に達成することができますかなり複雑なテキスト処理操作。広くさまざまなタスクを完了するために、自動処理のためのシェルスクリプトで使用されています。
sed的工作流程主要包括: 1. 读取:sed从输入流中读取一行内容不能够存储到临时的缓冲区中; 2. 执行:默认情况下所有的sed命令都在模式空间中按顺序地执行,除非指定了行的地址,否则sed命令将会再所有行上依次执行; 3. 显示:发送修改后的内容到输出流,再发送数据后,模式空间将会被清空。 注意:在所有的文件内容都被处理完成之前,上述过程将重复执行,直至所有内容都被处理完。
1)コマンドの構文とパラメータをsedは:
sed [选项] '操作' 参数 或 sed [选项] -f scriptfile 参数
主なパラメータの一般的なsedコマンドのオプションを:
あなたはいくつかの行などに最初の数行の間で変更する必要がある場合は、一般的な動作パラメータが含まれます:
2)のsedコマンドの使用例(変更が必要な場合は、次のアクションは、ファイル自体の内容は変更されませんのでご注意「-i」オプションを取る必要があります)
1.出力マッチングテキスト
[root@localhost ~]# sed -n 'p' test.txt //输出所有内容,等同于“cat test.txt”
[root@localhost ~]# sed -n '3p' test.txt //输出第三行内容
[root@localhost ~]# sed -n '3,5p' test.txt //输出3~5行
[root@localhost ~]# sed -n 'p;n' test.txt //输出所有奇数行,n表示读入下一行数据
[root@localhost ~]# sed -n 'n;p' test.txt //输出所有偶数行,n表示读入下一行数据
[root@localhost ~]# sed -n '1,5{p;n}' test.txt //输出第1行~第5行之间的奇数行(第1、3、5行)
[root@localhost ~]# sed -n '10,${n;p}' test.txt //输出第10行至文件尾部之间的偶数行(包括空行)
ケースとsedコマンドと正規表現を使用
正規表現と一緒にsedコマンドを、フォーマットは、わずかに異なっている「/」に囲まへの正規表現。
[root@localhost ~]# sed -n '/the/p' test.txt //输出包含“the”的行
[root@localhost ~]# sed -n '4,/the/p' test.txt //输出从第4行到都第一个包含“the”的行
[root@localhost ~]# sed -n '/the/=' test.txt //输出包含“the”的行所在的行号(等号(=)用来输出行号)
[root@localhost ~]# sed -n '/^PI/p' test.txt //输出以“PI”开头的行
[root@localhost ~]# sed -n '/\<wood\>/p' test.txt //输出包含单词wood的行,\<、\>代表单词边界
2.一致するテキストを削除します。
NLコマンドは、ファイル内の行数を計算するために使用され
[root@localhost ~]# nl test.txt | sed '3d' //删除第3行
[root@localhost ~]# nl test.txt | sed '3,5d' //删除第3~5行
[root@localhost ~]# nl test.txt | sed '/cross/d' //删除包含cross的行,原本的第8行被删除
[root@localhost ~]# nl test.txt | sed '/cross/! d' //删除不包含cross的行
[root@localhost ~]# sed '/\.$/d' test.txt //删除以“.”结束的行 [root@localhost ~]# sed '/^$/d' test.txt //删除所有空行 [root@localhost ~]# sed -e '/^$/{n;/^$/d}' test.txt //删除空行,连续的空行留一个
3.予選テキストを置き換えます
:オプションがSEDコマンド動作用いて交換する必要がありますS(文字列置換)、C(行全体/代替ブロック)、Y(文字変換)コマンドオプション等。テストファイルが要件を満たしていないので、以下のスクリーンショットではありません。
[root@localhost ~]# sed 's/the/THE/' test.txt //将每行中的第一个the替换为THE [root@localhost ~]# sed 's/l/L/2' test.txt //将每行中的第三个“l”替换为“L” [root@localhost ~]# sed 's/the/THE/g' test.txt //将文件中所有的“the”替换为“THE” [root@localhost ~]# sed 's/o//g' test.txt //将文件中所有的“o”删除 [root@localhost ~]# sed 's/^/#/' test.txt //在每行的行首插入“#”号 [root@localhost ~]# sed '/the/s/^/#/' test.txt //在包含“the”的每行行首插入“#”号 [root@localhost ~]# sed 's/$/EOF/' test.txt //在每行行尾插入字符串“EOF” [root@localhost ~]# sed '3,5s/the/THE/g' test.txt //将第3~5行中的所有“the”替换为“THE” [root@localhost ~]# sed '/the/s/o/O/g' test.txt //将包含“the”的所有行中的o替换为“O”
もっと「SED -i」コマンドがすぐに効果があります!
[root@localhost ~]# sed -i '1c 1111' a.txt //替换文中第一行的内容为“1111” [root@localhost ~]# sed -i '1a 1111' a.txt //在第一行后面插入一行内容,内容为“1111” [root@localhost ~]# sed -i '1i 2222' a.txt //在第一行前面插入一行内容,内容为“2222” [root@localhost ~]# sed -i '1d' a.txt //删除第一行内容 [root@localhost ~]# sed -n '1p' a.txt //打印出第一行的内容 [root@localhost ~]# sed -i '1s/2222/3333/g' a.txt //将文本第一行内容“2222”替换为“3333”
4.移行予選テキスト
移行テキスト操作のオプションがある場合に必要sedコマンドを使用:G、Gは、指定された行に追加クリップボード/カバーデータ、ファイルとして保存さwは、R&LTは、指定されたファイルを読み込み、Aは追加のコンテンツを指定します。
[root@localhost ~]# sed '/the/{H;d};$G' test.txt //将包含“the”的行迁移到文件末尾,“;”用于多个操作 [root@localhost ~]# sed '1,5{H;d};17G' test.txt //将第1~5行的内容转移到第17行后 [root@localhost ~]# sed '/the/w out.file' test.txt //将包含“the”的行另存为文件out.file [root@localhost ~]# sed '/the/r /etc/hostname' test.txt //将文件/etc/hostname的内容添加到包含“the”的每行以后 [root@localhost ~]# sed '3aNEW' test.txt //在第3行后面插入一个新行,内容为“NEW” [root@localhost ~]# sed '/the/aNEW' test.txt //在包含“the”的每行后插入一个新行,内容为“NEW” [root@localhost ~]# sed '3aNEW1\nNEW2' test.txt //在第3行后面多行内容,中间的“\n”表示换行
5.編集したスクリプトを使用してファイル
呼び出すために「-f」オプションで、sedスクリプト、(命令のマーキング1行につき1つ)のファイルに保存された編集指示を使用してください。
[root@localhost ~]# sed '1,5{H;d};17G' test.txt //将第1~5行内容转移至第17行后
上記の操作は、スクリプトファイル方式に変換されます。
[root@localhost ~]# vim 1.list 1,5H 1,5d 17G [root@localhost ~]# sed -f 1.list test.txt
直接ファイル動作例6.sed
vsftpdのサービスの設定を調整するために使用するスクリプトを、書く:匿名ユーザーを無効にしますが、ローカルユーザがログイン(また、書き込みを許可する)ことができます。
[root@localhost ~]# vim local_only_ftp.sh #!/bin/bash S="/usr/share/doc/vsftpd-3.0.2/EXAMPLE/INSERNET_SITE/vsftpd.conf" C="/etc/vsftpd/vsftpd.conf" #指定样本文件路径、配置文件路径 [ ! -e "$C.bak" ] && cp $C $C.bak #备份原来的配置文件,检测(配置文件.bak)是否存在,如果不存在则使用cp命令复制 sed -e '/^anonymous_enable/s/YES/NO/g' $S > $C sed -i -e '/^local_enable/s/NO/YES/g' -e '/^write_enable/s/NO/YES/g' $C grep "listen" $C || sed -i '$alisten=YES' $A #基于样本配置进行调整,覆盖现有文件 systemctl restart vsftpd systemctl enable vsftpd #重启ftp服务,并设置为开机自启动
awkコマンドツール
Linux / UNIXシステムでは、AWKを編集するための強力なツールであり、入力されたテキストは、出力フォーマットまたはコンテンツフィルタ処理の要件を満たすために指定されたパターンに応じてマッチングを見つけるために、ライン毎に読み出され、無缶かなり複雑なテキスト操作を達成するために、相互作用の場合には、広く自動化された、さまざまな構成タスクを完了するために、シェルスクリプトで使用されています。
コマンドの構文と概要1.awk
awk 选项 '模式或条件 { 编辑指令 }' 文件1 文件2 … //过滤并输出文件符合条件的内容 awk -f 脚本文件 文件1 文件2 … //从脚本中调用编辑指令,过滤并输出内容
* awkの実行結果は、印刷データの印刷フィールド機能で表示することができます。; AWKコマンドを使用して、あなたは「&&」と「||」論理演算子を使用することができ
-例えば+、などの単純な数学演算であることができる、/、%、^、それぞれ加算、減算、乗算、および除算、モジュロ、電源。**
awkは、標準入力ファイルまたは入力情報から読み込み、sedのように、情報は行ずつ読みを読まれます。違いは、AWKコマンドレコードとしてテキストファイルの行が、レコードのフィールドとして行(列)の特定の部分です。シェル変数の位置と同様、これらの異なるフィールド(列)、この方法は、$ 1、$ 2 ... $ 9で借りAWK動作するように、異なるカラムの手順、$ 0行全体を表します。異分野と異なる分野が指定された方法によって分離することができる、awkのデフォルトの区切り文字はスペースです。awkコマンドは、利用形態「-Fセパレータは、」区切り文字を指定することができます。
図の/ etc / passwdファイルの処理にawkコマンド:
awkには、次のようないくつかの特殊な組み込み変数を、含まれています。
2.awkコマンドの使用例
1)行出力テキスト
[root@localhost ~]# awk '{print}' test.txt //输出所有内容,等同于“cat test.txt” [root@localhost ~]# awk '{print $0}' test.txt //输出所有内容,等同于“cat test.txt” [root@localhost ~]# awk 'NR==1,NR==3{print}' test.txt //输出第1~3行的内容 [root@localhost ~]# awk '(NR>=1) && (NR<=3) {print}' test.txt //输出第1~3行的内容 [root@localhost ~]# awk 'NR==1 || NR==3{print}' test.txt //输出第1行、第3行的内容 [root@localhost ~]# awk '(NR%2)==1 {print}' test.txt //输出所有奇数行的内容 [root@localhost ~]# awk '(NR%2)==0 {print}' test.txt //输出所有偶数行的内容 [root@localhost ~]# awk '/^root/{print}' /etc/passwd //输出以“root”开头的行 [root@localhost ~]# awk '/nologin$/{print}' /etc/passwd //输出以“nologin”结尾的行 [root@localhost ~]# awk 'BEGIN {x=0} ;/\/bin\/bash$/{x++};END {print x}' /etc/passwd //统计以/bin/bash结尾的行数 [root@localhost ~]# grep -c "/bin/bash$" /etc/passwd //统计以/bin/bash结尾的行数 [root@localhost ~]# awk 'BEGIN{RS=""}; END{print NR}' /etc/squid/squid.conf //统计以空格分隔的文件段落数
注意:ときよりコマンド、「BEGIN ...... END」を使用
2)を押して、出力テキスト・フィールド
[root@localhost ~]# awk '{print $3}' test.txt //输出每行中(以空格分隔)的第3个字段 [root@localhost ~]# awk '{print $1,$3}' test.txt //输出每行中(以空格分隔)的第1个和第3个字段 [root@localhost ~]# awk -F ":" '$2==""{print}' /etc/shadow //输出/etc/shadow文件中(以“:”分隔)的第二个字段(密码为空的用户) [root@localhost ~]# awk 'BEGIN {FS=":"}; $2=""{print}' /etc/shadow //输出/etc/shadow文件中(以“:”分隔)的第二个字段(密码为空的用户) [root@localhost ~]# awk -F ":" '$7~"/bash"{print $1}' /etc/passwd //输出以“:”分隔且第7个字段中包含“/bash”的行的第1个字段 [root@localhost ~]# awk '($1~"nfs") && (NF==8) {print $1,$2}' /etc/services //输出包含8个字段且第1个字段中包含“nfs”的行的第1、2个字段 [root@localhost ~]# awk -F ":" '($7!="/bin/bash") && ($7!="/sbin/nologin") {print}' /etc/passwd //输出第7个字段既不为“/bin/bash”也不为“/bin/nologin”的所有行
3)パイプを通して、シェルコマンドは二重引用符を呼び出します
[ルート@ localhostの〜]#のawkの-F: 'のbash $ /印刷/ {| "トイレ-l"}' / etc / passwdファイルは
ユーザの数を呼び出す// "トイレ-l"コマンドの使用状況の統計"bashの"
[ルート〜@localhost] -C#のはgrep "のbash $" / etc / passwdファイル
//上記と同じ効果コマンド
[ルート@ localhostの〜]#件のawk 「{しばらくBEGIN | N( "W"のgetline)++; {プリントのn-2 }} '
//コマンドと力ああ統計"W"と呼ぶオンラインユーザー
印刷$ 0}'; getlineは| [ルート@ localhostの〜]#のawkは'{ "ホスト名" BEGIN
// "ホスト名"コマンドを呼び出し、出力電流をユーザ名
4)awkコマンドの簡単な数学を使って
[root@localhost ~]# awk 'BEGIN{ a=6;b=3;print"(a + b)=",(a + b)}' (a + b)= 9 [root@localhost ~]# awk 'BEGIN{ a=6;b=3;print"(a - b)=",(a - b)}' (a - b)= 3 [root@localhost ~]# awk 'BEGIN{ a=6;b=3;print"(a / b)=",(a / b)}' (a / b)= 2 [root@localhost ~]# awk 'BEGIN{ a=6;b=3;print"(a % b)=",(a % b)}' (a % b)= 0