学习笔记:CentOS7学习之二十四:expect-正则表达式-sed-cut的使用

时间:2023-12-18 09:45:32

学习笔记:CentOS7学习之二十四:expect-正则表达式-sed-cut的使用


本文用于记录学习体会、心得,兼做笔记使用,方便以后复习总结。内容基本完全参考学神教育教材,图片大多取材自学神教育资料,在此非常感谢MK老师和学神教育的优质教学。希望各位因学习需求而要进行转载时,能申明出处为学神教育,谢谢各位!


24.1 expect实现无交互登录

expect ([ɪkˈspekt] 期待 )是从它发展出来的。如果你想要写一个能够自动处理输入输出的脚本(如向用户提问并且验证密码)又不想面对C或者Perl,那么expect是你的最好的选择。它可以用来做一些linux下无法做到交互的一些命令操作

24.1.1 安装和使用expect

1)定义脚本执行的shell

#!/usr/bin/expect

这里定义的是expect可执行文件的链接路径(或真实路径),功能类似于bash等shell功能

2)set timeout 30

设置超时时间,单位是秒,如果设为timeout -1 意为永不超时

3)spawn

spawn 是进入expect环境后才能执行的内部命令,如果没有装expect或者直接在默认的SHELL下执行是找不到spawn命令的。不能直接在默认的shell环境中进行执行主要功能,它主要的功能是给ssh运行进程加个壳,用来传递交互指令。

4)expect

这里的expect同样是expect的内部命令

主要功能:判断输出结果是否包含某项字符串,没有则立即返回,否则就等待一段时间后返回,等待时间通过timeout进行设置

5)send

执行交互动作,将交互要执行的动作进行输入给交互指令

命令字符串结尾要加上"\r",如果出现异常等待的状态可以进行核查

6)exp_continue

继续执行接下来的交互操作

7)interact

执行完后保持交互状态,把控制权交给控制台;如果不加这一项,交互完成会自动退出

8)$argv

expect 脚本可以接受从bash传递过来的参数,可以使用 [lindex $argv n]获得,n从0开始,分别表示第一个,第二个,第三个……参数

例1:免密码通过SSH登录服务器(了解) 这里不是用密钥


[root@CentOs7_64_1_128 tmp]# vim ssh.exp set passwd "123456.com"
set timeout 30
# 设置超时时间,单位是秒;expect超时等待时间,默认timeout为10s spawn ssh $name@$ipaddr
# spawn是进入expect环境后才可以执行的expect内部命令,如果没有装expect或者直接在shell下执行是找不到spawn命令的。这个就
好比cd是shell的内建命令,离开shell,就无法执行cd一样。 它主要的功能是给ssh运行进程加个壳,用来传递交互指令。 expect {
"yes/no" {send "yes\r";exp continue} # 判断输出结果中是否有“yes\no”,有的话发送yes和回城,并且继续
"password" {send "$passwd\r"}
# 判断输出结果中是否有“password”,有的话发送“$passwd”和回城,执行交互动作,与手工输入密码的动作等效。
} expect "#"
# 判断输出结果中,是否有#,即是否登录成功。如果有继续向下执行,否则就继续等待,直到时间超时 send "touch /root/sshtest1.txt\r"
send "ls /etc > /root/sshtest1.txt\r"
send "mkdir /tmp/test0708\r"
send "exit\r"
expect eof
# 执行完上述命令后,退出expect,把控制权交给控制台,变回手工操作 [root@CentOs7_64_1_128 tmp]# expect ssh.exp
spawn ssh root@192.168.87.127
root@192.168.87.127's password:
Last login: Mon Jul 8 10:26:29 2019 from 192.168.87.127
[root@CentOs7_64_2_127 ~]# touch /root/sshtest1.txt
[root@CentOs7_64_2_127 ~]# ls /etc > /root/sshtest1.txt
[root@CentOs7_64_2_127 ~]# mkdir /tmp/test0708
[root@CentOs7_64_2_127 ~]# exit
登出 [root@CentOs7_64_2_127 ~]# ll /root # 查看发现命令执行成功
总用量 12
-rw-r--r--. 1 root root 0 6月 20 15:51 1.txt
-rw-r--r--. 1 root root 0 6月 20 15:51 2.txt
-rw-r--r--. 1 root root 0 6月 20 15:51 3.txt
-rw-r--r--. 1 root root 0 6月 20 15:51 4.txt
-rw-------. 1 root root 1821 6月 17 19:25 anaconda-ks.cfg
-rw-r--r--. 1 root root 1849 6月 17 11:27 initial-setup-ks.cfg
-rw-r--r--. 1 root root 2773 7月 8 10:43 sshtest1.txt
[root@CentOs7_64_2_127 ~]# ll /tmp
总用量 0
drwx------. 3 root root 17 7月 4 10:17 systemd-private-ca3a7facb04b4613935e0f5bb2bb2a69-bolt.service-WWgotR
drwx------. 3 root root 17 7月 4 10:16 systemd-private-ca3a7facb04b4613935e0f5bb2bb2a69-chronyd.service-EJWqEu
drwx------. 3 root root 17 7月 4 10:17 systemd-private-ca3a7facb04b4613935e0f5bb2bb2a69-colord.service-Q265Ng
drwx------. 3 root root 17 7月 4 10:16 systemd-private-ca3a7facb04b4613935e0f5bb2bb2a69-cups.service-bCcfaC
drwx------. 3 root root 17 7月 4 10:16 systemd-private-ca3a7facb04b4613935e0f5bb2bb2a69-rtkit-daemon.service-0HZIGo
drwxr-xr-x. 2 root root 6 7月 8 10:43 test0708
drwx------. 2 yangjie yangjie 6 6月 20 15:38 tracker-extract-files.1000
drwx------. 2 root root 6 7月 2 11:46 vmware-root_6563-1714820560
drwx------. 2 root root 6 7月 4 10:17 vmware-root_6567-1723143253
drwx------. 2 root root 6 6月 24 15:43 vmware-root_6623-1991713811
[root@CentOs7_64_2_127 ~]# cat /root/sshtest1.txt
abrt
adjtime
aliases
aliases.db
alsa
alternatives
anacrontab

例2:对服务器批量管理(了解一下)


[root@CentOs7_64_1_128 tmp]# vim ssh1.txt #编辑服务器列表 192.168.87.126 123456.com
192.168.87.127 123456.com [root@CentOs7_64_1_128 tmp]# vim ssh.exp #!/usr/bin/expect
set ipaddr [lindex $argv 0] # 将参数一传做IP地址
set name root
set passwd [lindex $argv 1] # 将参数二传做密码
set timeout 30 spawn ssh $name@$ipaddr expect {
"yes/no" {send "yes\r";exp continue}
"password" {send "$passwd\r"}
} expect "#" send "touch /root/sshtest1.txt\r"
send "ls /etc > /root/sshtest1.txt\r"
send "mkdir /tmp/test0708\r"
send "exit\r"
expect eof [root@CentOs7_64_1_128 tmp]# vim login.sh # 编辑登入脚本 #!/bin/bash echo "login beginning.." for ip in $(awk '{print $1}' /tmp/ssh1.txt) # 读取ssh1.txt的参数
do
passwd=`grep $ip /tmp/ssh1.txt|awk '{print $2}'`
expect /tmp/ssh.exp $ip $passwd # 将ip和密码传给ssh.exp
done [root@CentOs7_64_1_128 tmp]# bash login.sh # 运行脚本
login beginning..
spawn ssh root@192.168.87.126
root@192.168.87.126's password:
Last login: Mon Jul 8 11:29:17 2019 from 192.168.87.128
[root@localhost ~]# touch /root/sshtest1.txt
[root@localhost ~]# ls /etc > /root/sshtest1.txt
[root@localhost ~]# mkdir /tmp/test0708
[root@localhost ~]# exit
logout
Connection to 192.168.87.126 closed.
spawn ssh root@192.168.87.127
root@192.168.87.127's password:
Last login: Mon Jul 8 11:26:14 2019 from 192.168.87.128
[root@CentOs7_64_2_127 ~]# touch /root/sshtest1.txt
[root@CentOs7_64_2_127 ~]# ls /etc > /root/sshtest1.txt
[root@CentOs7_64_2_127 ~]# mkdir /tmp/test0708
mkdir: 无法创建目录"/tmp/test0708": 文件已存在
[root@CentOs7_64_2_127 ~]# exit
登出
Connection to 192.168.87.127 closed.

24.2 正则表达式的使用

学习笔记:CentOS7学习之二十四:expect-正则表达式-sed-cut的使用

正则表达式,又称规则表达式。(英语:Regular Expression [ˈreɡjulə] 规则的 [ iksˈpreʃən] 表达 ),在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。

正则表达式不只有一种,而且LINUX中不同的程序可能会使用不同的正则表达式,如:

工具:grep sed awk

LINUX中常用的有两种正则表达式引擎

  • 基础正则表达式:BRE
  • 扩展正则表达式: ERE

24.2.1 Shell正则表达式的组成

基础正则表达式

特别字符 描述
$ 匹配输入字符串的结尾位置。要匹配 $ 字符本身,请使用 $
( ) 标记一个子表达式的开始和结束位置。要匹配这些字符,请使用 ( 和 )
* 匹配前面的子表达式零次或多次。要匹配 * 字符,请使用 *
+ 匹配前面的子表达式一次或多次。要匹配 + 字符,请使用 +
. 匹配除换行符 \n 之外的任何单字符。要匹配 . ,请使用 .
[ 标记一个中括号表达式的开始。要匹配 [,请使用 [
? 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符。要匹配 ? 字符,请使用 ?
\ 将下一个字符标记为或特殊字符、或原义字符、或向后引用、或八进制转义符。例如, 'n' 匹配字符 'n'。'\n' 匹配换行符。序列 '\' 匹配 "",而 '(' 则匹配 "("
^ 匹配输入字符串的开始位置,除非在方括号表达式中使用,此时它表示不接受该字符集合。要匹配 ^ 字符本身,请使用 ^
{ 标记限定符表达式的开始。要匹配 {,请使用 {
¦ 指明两项之间的一个选择。要匹配 ¦,请使用 ¦ 如: Y ¦ y

定位符

字符 说明
^ 匹配输入字符串开始的位置
$ 匹配输入字符串结尾的位置

非打印字符

字符 描述
\n 匹配一个换行符
\r 匹配一个回车符
\t 匹配一个制表符

例1:统计/etc/ssh/sshd_config文件中除去空行和#号开头的行的行数


[root@CentOs7_64_1_128 tmp]# grep -v "^$\|^#" /etc/ssh/ssh_config
# 使用基础正则表达式时,|前要使用转义符,作为或运算符使用
Host *
GSSAPIAuthentication yes
ForwardX11Trusted yes
SendEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
SendEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
SendEnv LC_IDENTIFICATION LC_ALL LANGUAGE
SendEnv XMODIFIERS
[root@CentOs7_64_1_128 tmp]# grep -E -v "^$|^#" /etc/ssh/ssh_config
# 使用扩展正则表达式时,直接使用|作为或运算符使用
Host *
GSSAPIAuthentication yes
ForwardX11Trusted yes
SendEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
SendEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
SendEnv LC_IDENTIFICATION LC_ALL LANGUAGE
SendEnv XMODIFIERS
[root@CentOs7_64_1_128 tmp]# egrep -v "^$|^#" /etc/ssh/ssh_config
# 使用egrep即使用扩展正则表达式
Host *
GSSAPIAuthentication yes
ForwardX11Trusted yes
SendEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
SendEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
SendEnv LC_IDENTIFICATION LC_ALL LANGUAGE
SendEnv XMODIFIERS

例2:点字符


[root@CentOs7_64_1_128 tmp]# grep .ot /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
setroubleshoot:x:987:981::/var/lib/setroubleshoot:/sbin/nologin
pcp:x:984:978:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin

24.3 sed流编辑器

24.3.1 sed strem editor 流编辑器

sed编辑器是一行一行的处理文件内容的。正在处理的内容存放在模式空间(缓冲区)内,处理完成后按照选项的规定进行输出或文件的修改。

接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;

sed也是支持正则表达式的,如果要使用扩展正则加参数-r

sed的执行过程:

  • 一次读取一行数据
  • 根据我们提供的规则来匹配相关的数据,比如查找root。
  • 按照命令修改数据流中的数据,比如替换
  • 将结果进行输出
  • 重复上面四步

24.3.2 如何使用

语法格式:sed [options] ‘[commands]’ filename


[root@CentOs7_64_1_128 tmp]# echo "this is apple"|sed 's/apple/dog/'
this is dog

24.3.3 sed选项|参数

options:

  • -a 在当前行下面插入文件
  • -n 隐藏执行过程,只显示执行结果
  • -e 执行多个sed指令
  • -f 运行脚本
  • -i 编辑文件内容 ***
  • -i.bak 编辑的同时创造.bak的备份
  • -r 使用扩展的正则表达式

命令:

  • i 在当前行上面插入文件
  • c 把选定的行改为新的指定的文本
  • p 打印 ***
  • d 删除 ***
  • r/R 读取文件/一行
  • w 另存
  • s 查找
  • y 替换
  • h 拷贝模板块的内容到内存中的缓冲区。
  • H 追加模板块的内容到内存中的缓冲区。
  • g 获得内存缓冲区的内容,并替代当前模板块中的文本。
  • G 获得内存缓冲区的内容,并追加到当前模板块文本的后面
  • D 删除\n之前的内容
  • P 打印\n之前的内容

替换标记:

  • 数字:表明新文本将替换第几处模式匹配的地方
  • g:表示新文本将会替换所有匹配的文本
  • \1:子串匹配标记,前面搜索可以用元字符集(..),
  • &:保留搜索到的字符用来替换其它字符

1) sed匹配字符集:

  • ^ 匹配行开始,如:/^sed/匹配所有以sed开头的行。
  • $ 匹配行结束,如:/sed$/匹配所有以sed结尾的行。
  • . 匹配一个非换行符的任意字符,如:/s.d/匹配s后接一个任意字符,最后是d。
    • 匹配0个或多个字符,如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。

例1:s 只替换第一个匹配到的字符,将passwd中的root用户替换成yang


[root@CentOs7_64_1_128 tmp]# sed 's/root/yang/' ./passwd
yang:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin

例2:全面替换标记g


[root@CentOs7_64_1_128 tmp]# sed 's/root/yang/g' ./passwd
yang:x:0:0:yang:/yang:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin

例3: 将sed中默认的/ 定界符改成#号


[root@CentOs7_64_1_128 tmp]# sed 's#/bin/bash#/sbin/nologin#g' /etc/passwd
root:x:0:0:root:/root:/sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

2)按行查找替换

写法如下:

  • 用数字表示行范围;$表示行尾
  • 用文本模式配置来过滤

例1:单行替换,将第2行中bin替换成xuegod


[root@CentOs7_64_1_128 tmp]# sed '2s/bin/yang/g' ./passwd
root:x:0:0:root:/root:/bin/bash
yang:x:1:1:yang:/yang:/syang/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin

例2:多行替换,如果涉及到多行处理,用逗号表示行间隔。


[root@CentOs7_64_1_128 tmp]# sed '2,6s/sbin/yangyang/g' ./passwd # 将2到6行的sbin替换成yangyang
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/yangyang/nologin
daemon:x:2:2:daemon:/yangyang:/yangyang/nologin
adm:x:3:4:adm:/var/adm:/yangyang/nologin
lp:x:4:7:lp:/var/spool/lpd:/yangyang/nologin
sync:x:5:0:sync:/yangyang:/bin/sync [root@CentOs7_64_1_128 tmp]# sed '2,$s/sbin/yangyang/g' ./passwd # 将2行道最后一行的sbn替换成yangyang
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/yangyang/nologin
daemon:x:2:2:daemon:/yangyang:/yangyang/nologin
adm:x:3:4:adm:/var/adm:/yangyang/nologin
lp:x:4:7:lp:/var/spool/lpd:/yangyang/nologin
sync:x:5:0:sync:/yangyang:/bin/sync
shutdown:x:6:0:shutdown:/yangyang:/yangyang/shutdown
halt:x:7:0:halt:/yangyang:/yangyang/halt
mail:x:8:12:mail:/var/spool/mail:/yangyang/nologin
operator:x:11:0:operator:/root:/yangyang/nologin
games:x:12:100:games:/usr/games:/yangyang/nologin
ftp:x:14:50:FTP User:/var/ftp:/yangyang/nologin
nobody:x:99:99:Nobody:/:/yangyang/nologin
ods:x:999:999:softhsm private keys owner:/var/lib/softhsm:/yangyang/nologin
pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/yangyang/nologin
systemd-network:x:192:192:systemd Network Management:/:/yangyang/nologin

3)d 删除第2行到第4行的内容


[root@CentOs7_64_1_128 tmp]# cat ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.87.128 CentOs7_64_1_128 [root@CentOs7_64_1_128 tmp]# sed '2,4d' ./hosts # 删除第2到4行进行输出
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
[root@CentOs7_64_1_128 tmp]# sed '/192.168/d' ./hosts # 删除含有192.168的行进行输出
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6

4)添加行

  • 命令i(insert插入),在当前行前面插入一行 i\
  • 命令a(append附加),在当前行后面添加一行 a\

例1:插入

[root@CentOs7_64_1_128 tmp]# echo "hello world"|sed 'i\yang'
yang
hello world

例2:追加

[root@CentOs7_64_1_128 tmp]# echo "hello world"|sed 'a\yang'
hello world
yang

例3:在文件最后追加内容


[root@CentOs7_64_1_128 tmp]# sed '$a\192.168.87.127 CenOs7_64_127' ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.87.128 CentOs7_64_1_128
192.168.87.127 CenOs7_64_127

例4:在文件中第2行之后,开始追加内容


[root@CentOs7_64_1_128 tmp]# sed '2a\192.168.87.127 CenOs7_64_127' ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.87.127 CenOs7_64_127 192.168.87.128 CentOs7_64_1_128

例5:在文件中第2行到第4行之后分别追加内容

[root@CentOs7_64_1_128 tmp]# sed '2,4a\192.168.87.127 CenOs7_64_127' ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.87.127 CenOs7_64_127 192.168.87.127 CenOs7_64_127
192.168.87.128 CentOs7_64_1_128
192.168.87.127 CenOs7_64_127

*5)修改行命令c (change) c*

例1:将第2行内容改成192.168.81.156 CentOS_1_126


[root@CentOs7_64_1_128 tmp]# sed '2c\192.168.87.126 CentOs6_1_126' ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
192.168.87.126 CentOs6_1_126 192.168.87.128 CentOs7_64_1_128

例2:将第2行到最后全部修改成192.168.81.156 CentOS_1_126


[root@CentOs7_64_1_128 tmp]# sed '2,$c\192.168.87.126 CentOs6_1_126' ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
192.168.87.126 CentOs6_1_126

例3:将包括192.168.87.128行的内容修改成192.168.87.127 CentOs-2-127


[root@CentOs7_64_1_128 tmp]# sed '/192.168.87.128/c\192.168.87.127 CentOs-2-127' ./hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.87.127 CentOs-2-127

6)打印,直接输入文件中的内容


[root@CentOs7_64_1_128 tmp]# sed -n '2p' ./hosts
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6

7)将修改或过滤出来的内容保存到另一个文件中

例1:将passwd中的包括root字样的行保存到 a.txt 中


[root@CentOs7_64_1_128 tmp]# sed -n '/root/w a.txt' /etc/passwd
[root@CentOs7_64_1_128 tmp]# cat a.txt
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

8)-i 对原文件修改,保存( 必会 ) 使用场景: 替换或修改服务器配置文件


[root@CentOs7_64_1_128 tmp]# sed -i 's/root/yang/' ./passwd
[root@CentOs7_64_1_128 tmp]# head -1 passwd
yang:x:0:0:root:/root:/bin/bash

修改IP地址为192.168.1.65


[root@CentOs7_64_1_128 tmp]# sed -i 's/IPADDR=192.168.87.128/IPADDR=192.168.87.125/' ./ifcfg-ens33
# 寻找IPADDR=192.168.87.128,替换成/IPADDR=192.168.87.125
[root@CentOs7_64_1_128 tmp]# cat ifcfg-ens33 # 返现修改成功
TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=static
IPADDR=192.168.87.125
NETMASK=255.255.255.0
GATEWAY=192.168.87.2
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=ens33
UUID=f8e250be-4e78-49f6-87ea-34b476f66305
DEVICE=ens33
ONBOOT=yes
IPV6_PRIVACY=no
PREFIX=24
DNS1=8.8.8.8
DNS2=114.114.114.114
ZONE=public

24.4 cut命令

24.4.1 cut常用参数

cut命令用来显示行中的指定部分,删除文件中指定字段。

说明:该命令有两项功能,其一是用来显示文件的内容,它依次读取由参数file所指明的文件,将它们的内容输出到标准输出上;其二是连接两个或多个文件,如cut fl f2 > f3将把文件fl和fn的内容合并起来,然后通过输出重定向符“>”的作用,将它们放入文件f3中。

语法: cut(选项)(参数)

选项

  • -b:仅显示行中指定范围的字节数;
  • -c:仅显示行中指定范围的字符;
  • -d:指定字段的分隔符,默认的字段分隔符为“TAB”;
  • -f:显示指定字段的内容;

示例:

例1:打印第1个到第3个字符:


[root@CentOs7_64_1_128 tmp]# cut -c1-5 /etc/passwd
root:
bin:x
daemo
adm:x
lp:x:
sync:
shutd
halt:
mail:
opera
games
ftp:x
nobod
ods:x
pegas
syste
dbus:
polki
apach
unbou

例2:打印前2个字符:


[root@CentOs7_64_1_128 tmp]# cut -c-2 /etc/passwd
ro
bi
da
ad
lp
sy
sh
ha
ma
op
ga
ft
no
od
pe
sy
db
po
ap
un
li

例3:打印从第5个字符开始到结尾:


[root@CentOs7_64_1_128 tmp]# cut -c5- /etc/passwd
:x:0:0:root:/root:/bin/bash
x:1:1:bin:/bin:/sbin/nologin
on:x:2:2:daemon:/sbin:/sbin/nologin
x:3:4:adm:/var/adm:/sbin/nologin
:4:7:lp:/var/spool/lpd:/sbin/nologin
:x:5:0:sync:/sbin:/bin/sync
down:x:6:0:shutdown:/sbin:/sbin/shutdown
:x:7:0:halt:/sbin:/sbin/halt
:x:8:12:mail:/var/spool/mail:/sbin/nologin
ator:x:11:0:operator:/root:/sbin/nologin
s:x:12:100:games:/usr/games:/sbin/nologin
x:14:50:FTP User:/var/ftp:/sbin/nologin
dy:x:99:99:Nobody:/:/sbin/nologin
x:999:999:softhsm private keys owner:/var/lib/softhsm:/sbin/nologin

24.5 实战bash查看详细的执行过程

bash -x test.bash #查看bash详细的执行过程

[root@CentOs7_64_1_128 tmp]# bash -x for9.sh

  • (( a=1,b=10 ))
  • (( a<=10 ))
  • echo 'a = 1, b = 10'

    a = 1, b = 10
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 2, b = 9'

    a = 2, b = 9
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 3, b = 8'

    a = 3, b = 8
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 4, b = 7'

    a = 4, b = 7
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 5, b = 6'

    a = 5, b = 6
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 6, b = 5'

    a = 6, b = 5
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 7, b = 4'

    a = 7, b = 4
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 8, b = 3'

    a = 8, b = 3
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 9, b = 2'

    a = 9, b = 2
  • (( a++,b-- ))
  • (( a<=10 ))
  • echo 'a = 10, b = 1'

    a = 10, b = 1
  • (( a++,b-- ))
  • (( a<=10 ))


END

2019-7-8 18:33:33