个人博客网:https://wushaopei.github.io/    (你想要这里多有)

十、Shell工具(重点)

1、cut

cut 的工作就是“剪”,具体的说就是在文件中负责剪切数据用的。 cut 命令从文件的每一好难过剪切字节、字符和字段并将这些字节、字符和字段输出。

1.1 基本用法

cut [选项参数] filename

说明: 默认分隔符是制表符

1.2 选项参数说明

   选项参数   功能
   -f 列好,提取第几列
  -d

分隔符,按照指定分隔符分割列

1.3 案例实操

(0)数据准备

[root@rich datas]# touch cut.txt
[root@rich datas]# vim cut.txt dong shen //一个空格
guan zhen //一个空格
wo wo //两个空格,后者属于第三列
lai lai //两个空格,后者属于第三列
le le //两个空格,后者属于第三列

(1)切割 cut.txt 第一列

[root@rich datas]# cut -d " " -f 1 cut.txt
dong
guan
wo
lai
le

(2)切割 cut.txt 第二、三列

[root@rich datas]# cut -d " " -f 2,3 cut.txt
shen
zhen
wo
lai
le

(3)在cut.txt文件中切割出 guan

[root@rich datas]# cat cut.txt |grep guan|cut -d " " -f 1
guan

(4)选取系统PATH变量值,第2个“:”开始后的所有路径:

[root@rich datas]# echo $PATH
/opt/jdk1.8.0_121/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
[root@rich datas]# echo $PATH|cut -d : -f 3-
/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

(5)切割 ifconfig 后打印的IP地址

[root@rich datas]# cat cut.txt|grep inet
inet 192.168.254.118 netmask 255.255.255.0
[root@rich datas]# ifconfig ens33 | grep "inet "|cut -d "t" -f 2|cut -d " " -f 2
192.168.254.118

2、sed

sed 是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”,接着用 sed 命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,知道文件末尾。文件内容并没有改变,除非你使用重定向存储输出。

2.1基本用法

sed[选项参数]  ‘command’ filename

2.2 选项参数说明

选项参数  功能
  -e 直接在指令列模式上进行sed 的动作编辑

2.3 命令功能描述

命令

 功能描述

a

新增, a 的后面可以接字符串,在下一行出现
 d 删除
 s 查找并替换

2.4 案例实操

(0)数据准备

[root@rich datas]# vim sed.txt
[root@rich datas]# cat sed.txt
dong shen
guan zhen
wo wo
lai lai le le

(1)将“mei nv” 这个单词插入到 sed.txt 第二行下,打印

[root@rich datas]# sed "2a mei nv" sed.txt
dong shen
guan zhen
mei nv
wo wo
lai lai le le

注意: 文件并没有改变

(2)删除sed.txt 文件所有包含 wo 的行

[root@rich datas]# sed "/wo/d" sed.txt
dong shen
guan zhen
lai lai le le

(3)将sed.txt 文件中 wo 替换为 ni

[root@rich datas]# sed "s/wo/ni/g" sed.txt
dong shen
guan zhen
ni ni
lai lai le le

注意: ‘g’表示 global,全部替换

(4)将sed.txt 文件中的第二行删除并将 wo 替换为 ni

[root@rich datas]# sed -e "2d" -e "s/wo/ni/g" sed.txt
dong shen
ni ni
lai lai le le

3、 awk

一个强大的文本分析工具,把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理

3.1 基本用法

awk[选项参数]   ‘patternl{action1} patternl2{action2}....’ filename

pattern: 表示 AWK 在数据中查找的内容,就是匹配模式

action :  在找到匹配内容是所执行的一系列命令

3.2 选项参数说明

选项参数 功能
   -F 指定输入文件拆分隔符
   -v 赋值一个用户定义变量

3.3 案例实操

(0)数据准备

cp /etc/passwd ./

[root@rich datas]# chown root:root passwd 

[root@rich datas]# cat passwd
root:x:0:0:root:/root:/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
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

(1)搜索passwd 文件以 root 关键字开头的所有行,并输出改行的第七列。

[root@rich datas]# awk -F : '/^root/ {print $7}' passwd
/bin/bash

(2)搜索 passwd 文件以 root 关键字开头的所有行,并输出改行的第一列和第七列,中间以 “ ,” 好分割

[root@rich datas]# awk -F : '/^root/ {print $1","$7}' passwd
root,/bin/bash

注意: 只有匹配了pattern  的行才会执行action

(3) 只显示/etc/passwd 的第一列和第七列,以逗号分割,且在所有行前面添加列名user,shell 在最后一行添加“dahaige, /bin/zuishuai”。

[root@rich datas]# awk -F : 'BEGIN{print "user,shell"} {print $1","$7} END{print "wenmin,bin/zuimei"}' passwd
user,shell
root,/bin/bash
bin,/sbin/nologin
.................
mysql,/bin/bash
elasticsearch,/sbin/nologin
wenmin,bin/zuimei

注意: BEGIN 在所有数据读取行之前执行;END 在所欲数据执行之后执行。

(4) 将passwd 文件中的用户 id  增加数值 1 并输出

[root@rich datas]# awk -F : -v i=1 '{print $3+i}' passwd 

1
2
3
4
5
6
7
8
9

3.4 awk 的内置变量

变量 说明
FILENAME 文件名
NR 已读的记录数
NF 浏览记录的域的个数(切割后,列的个数)

3.5 案例实操

(1)统计passwd 文件名,每行的行号,每行的列数

[root@rich datas]# awk -F : '{print FILENAME ","NR"," NF}' passwd
passwd,1,7
passwd,2,7
passwd,3,7
。。。。。。。。。。。。

(2)切割IP

[root@rich datas]# ifconfig ens33 | grep "inet " |awk -F " " '{print $2}'
192.168.254.118

(3)查询 sedtxt 中空行所在的行号

[root@rich datas]# awk '/^$/{print NR}' sed.txt
5
[root@rich datas]# cat sed.txt
dong shen
guan zhen
wo wo
lai lai le le

4、 sort

sort  命令是在 Linux 里非常有用,它将文件进行排序,并将排序结果标准输出。

4.1 基本语法

sort(选项参数)

选项 说明
 -n 依照数值的大小排序
 - r 以相反的顺序来排序
 -t 设置排序时所用的分隔字符
 -k 指定需要排序的列

参数: 指定待排序的文件列表

4.2 案例实操

(0)数据准备

[root@rich datas]# touch sort.sh
[root@rich datas]# vim sort.sh
[root@rich datas]# cat sort.sh
bb:40:5.4
bd:20:4.2
xz:50:2.3
cls:10:3.5
ss:30:1.6

(1)按照 “ :” 分割后的第三列倒序排序

[root@rich datas]# sort -t : -nrk 2 sort.sh
xz:50:2.3
bb:40:5.4
ss:30:1.6
bd:20:4.2
cls:10:3.5

十一、企业真实面试题

1、京东

问题1: 使用Linux 命令查询file1中空行所在的行号

答案:

[root@rich datas]# awk '/^$/{print NR}' sed.txt
5

问题2: 有文件 chengji.txt 内容如下:

张三 40

李四 50

王五 60

使用Linux 命令计算第二列的和并输出

[root@rich datas]# cat chengji.txt | awk -F " " '{sum+=$2} END{print sum}'
150

2、搜狐&和讯网

问题1: Shell 脚本里如何检查一个文件是否存在? 如果不存在该如何处理?

#!/bin/bash

if [ -f file.txt ]; then
echo "文件存在!"
else
echo "文件不存在"
fi

3、新浪

问题1: 用Shell写一个脚本,对文本中无序的一列数字排序

root@rich datas]# touch test.txt
[root@rich datas]# vim test.txt
[root@rich datas]# sort -n test.txt | awk '{a+=$0;print $0}END{print "SUM="a}'
1
2
2
3
4
5
6
7
8
9
10
SUM=57

4、金和网络

问题1: 请用shell脚本写出查找当前文件夹(/home)下所有的文本文件内容中包含有字符“shen”的文件名称

[root@rich datas]# grep -r shen /home
/home/wenmin/datas/cut.txt:dong shen
/home/wenmin/datas/sed.txt:dong shen
[root@rich datas]# grep -r shen /home | cut -d " " -f 1
/home/wenmin/datas/sed.txt:dong
[root@rich datas]# grep -r shen /home | cut -d " " -f 2
shen
shen

Shell 脚本(五) Shell 工具 及 企业面试题的更多相关文章

  1. shell脚本动画小工具

    shell脚本动画小工具 看gif图: shell脚本版 脚本内容如下: #!/usr/bin/env bash ## ---------------------------------------- ...

  2. shell脚本学习—Shell执行脚本

    Shell作用是解释执行用户的命令,用户输入一条命令,Shell就解释执行这一条,这种方式称为交互式,但还有另一种执行命令的方式称为批处理方式,用户事先写一个Shell脚本,Shell可以一次把这些命 ...

  3. shell脚本调试之工具——bashdb

    bash是Unix/Linux操作系统最常用的shell之一,它非常灵活,和awk.c++配合起来异常强大 以下使用一个测试脚本来说明使用bash调试的方法 test.sh #!/bin/bash e ...

  4. linux crontab定时任务运行shell脚本(shell执行sql文件)

    https://www.cnblogs.com/tiankongjava/p/6106743.html 今天做个linux定时任务(每晚12点把表汇总). 顺便写个博客记录一下~~ 为什么用linux ...

  5. Shell脚本之一 Shell脚本简介

    一.什么是shell? 我们平时所说的 Shell 可以理解为 Linux 系统提供给用户的使用界面.Shell 为用户提供了输入命令和参数并可得到命令执行结果的环境.当一个用户登录 Linux 之后 ...

  6. shell脚本(2)-shell脚本语法

    一.如何抒写shell脚本 1.shell脚本的命名 名字要有意义,不要以a.b.c.1.2.3这种方式命令,建议以sh结尾,在30个字节内,例如:check_memory.sh  2.shell脚本 ...

  7. 【shell脚本】shell脚本实现的 函数差集查找

    文本地址 点击关注微信公众号 wenyuqinghuai 分享提纲: 1. 问题背景 2. 代码实现 1.问题背景 在做公司的测试的自动化测试时,覆盖了一些开发代码的函数,但是那些还没有做,使用一个函 ...

  8. Shell脚本、Shell脚本结构、date命令的用法、变量

    1.Shell脚本: shell是一种脚本语言 目的:可以实现自动化运维,能大大增加运维的效率.2.Shell脚本结构:   #!/bin/bash  以#!/bin/bash开头,即以/bin/ba ...

  9. gitlab webhook php exec 调用 shell 脚本。shell 脚本中调用 git pull 命令无法执行。

    情况如下: 我在ubuntu server 14.04 上面安装了gitlab,来托管项目代码.然后想通过gitlab的web hook 功能来做测试服务器代码自动化更新代码功能.现在遇到一个问题:就 ...

随机推荐

  1. u-boot spl 学习总结

    什么是SPL? SPL(secondary program loader)是一个十分小的bin文件,它是用来引导主u-boot文件.对于一些SRAM很小的SOC,无法一次性加载ROM中的bootloa ...

  2. .NETcore中使用jwt来对api进行身份验证

    对于 登陆,身份,授权这之类的操作,我们最常用的几种方法无非就是 cookie session token 这三者的差别 https://www.cnblogs.com/moyand/p/904797 ...

  3. [hdu4292]最大流,拆点

    题意:给定每个人所喜欢的食物和饮料种类以及每种食物和饮料的数量,一个人需要一种食物和一种饮料(数量为1即可),问最多满足多少人的需要 思路:由于食物和饮料对于人来说需要同时满足,它们是“与”的关系,所 ...

  4. [hdu4911]逆序对相关

    思路:由于只能交换相邻的数,所以每次最多减小1个逆序对(且如果存在逆序对那么肯定可以减小1个)!于是乎..就是统计逆序对的裸题了.树状数组或归并都行. #pragma comment(linker, ...

  5. layui的layer.msg,form提交

    layer.msg('提示文字',{shift:1,time:2000},function(){ location.reload();});其中shift是提示框的动画样式,-1为无动画form.on ...

  6. Docker之save、load、export、import命令

    Docker的镜像和容器可以有两种方式导出 1.Docker save #ID or #Name 2.Docker save #ID or #Name docker save和docker expor ...

  7. zabbix server优化与迁移

    zabbix server优化与迁移 1. 概述 zabbix 系统其实分3个大部分,一个是server本身,另一个是php的httpd服务,第三个是非常需要优化的数据库.公司的zabbix监控主机在 ...

  8. Failed to start mongod.service: Unit not found

    其实自己用惯的是MYSQL,然后项目最后一步完善数据读写的部分,本来打算用mysql的,然而在centOS系统上发现安装总是出问题,后来查找一下资料,发现centOS系统上一般用的是Mariadb,这 ...

  9. 使用react的一点提醒17/10/26

    1.不直接操作dom 今天在和同学讨论的时候,发现了一些以前没注意的问题. 这段时间自己学习时一直都是用原生js写代码,但是以前在公司经常使用jq,也不知不觉间让我习惯了操作dom的倾向. 使用vue ...

  10. Poj 最短路和次短路的个数 Dij+优化?。

    Description Tour operator Your Personal Holiday organises guided bus trips across the Benelux. Every ...