shell入门

文章目录

  • shell入门
  • 一、文本处理工具
  • 1. grep工具
  • 2. cut工具
  • 3. sort工具
  • 4.uniq工具
  • 5.tee工具
  • 6.diff工具
  • 7. paste工具
  • 8. tr工具
  • 二、bash的特性
  • 1 、常用的通配符
  • 2、bash中的引号(重点)

一、文本处理工具

1. grep工具

grep是行过滤工具;用于根据关键字进行行过滤

语法和选项

语法:

# grep [选项] '关键字' 文件名

常见选项:

OPTIONS:-i: 不区分大小写
-v: 查找不包含指定内容的行,反向选择
-w: 按单词搜索
-o: 打印匹配关键字
-c: 统计匹配到的行数
-n: 显示行号
-r: 逐层遍历目录查找
-A: 显示匹配行及后面多少行
-B: 显示匹配行及前面多少行
-C: 显示匹配行前后多少行
-l:只列出匹配的文件名
-L:列出不匹配的文件名
-e: 使用正则匹配
-E:使用扩展正则匹配
^key:以关键字开头
key$:以关键字结尾
^$:匹配空行
--color=auto :可以将找到的关键词部分加上颜色的显示

颜色显示(别名设置)

临时设置:
# alias grep='grep --color=auto' //只针对当前终端和当前用户生效
永久设置:
1)全局(针对所有用户生效)
vim /etc/bashrc
alias grep='grep --color=auto'
source /etc/bashrc
2)局部(针对具体的某个用户)
vim ~/.bashrc
alias grep='grep --color=auto'
source ~/.bashrc

举例说明:

# grep -i root passwd 忽略大小写匹配包含root的行
# grep -w ftp passwd 精确匹配ftp单词
# grep -w hello passwd 精确匹配hello单词;自己添加包含hello的行到文件
# grep -wo ftp passwd 打印匹配到的关键字ftp
# grep -n root passwd 打印匹配到root关键字的行好
# grep -ni root passwd 忽略大小写匹配统计包含关键字root的行
# grep -nic root passwd 忽略大小写匹配统计包含关键字root的行数
# grep -i ^root passwd 忽略大小写匹配以root开头的行
# grep bash$ passwd 匹配以bash结尾的行
# grep -n ^$ passwd 匹配空行并打印行号
# grep ^# /etc/vsftpd/vsftpd.conf 匹配以#号开头的行
# grep -v ^# /etc/vsftpd/vsftpd.conf 匹配不以#号开头的行
# grep -A 5 mail passwd 匹配包含mail关键字及其后5行
# grep -B 5 mail passwd 匹配包含mail关键字及其前5行
# grep -C 5 mail passwd 匹配包含mail关键字及其前后5行

2. cut工具

cut是列截取工具,用于列的截取

语法和选项

语法:

# cut 选项 文件名

常见选项:

-c: 以字符为单位进行分割,截取
-d: 自定义分隔符,默认为制表符\t
-f: 与-d一起使用,指定截取哪个区域

举例说明:

# cut -d : -f 1 1.txt 以:冒号分割,截取第1列内容
# cut -d : -f 1,6,7 1.txt 以:冒号分割,截取第1,6,7列内容
# cut -c 4 1.txt 截取文件中每行第4个字符
# cut -c 1-4 1.txt 截取文件中每行的1-4个字符
# cut -c 4-10 1.txt 截取文件中每行的4-10个字符
# cut -c 5- 1.txt 从第5个字符开始截取后面所有字符

3. sort工具

sort工具用于排序;它将文件的每一行作为一个单位,从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出

语法和选项

-u :去除重复行
-r :降序排列,默认是升序
-o : 将排序结果输出到文件中,类似重定向符号>
-n :以数字排序,默认是按字符排序
-t :分隔符
-k :第N列
-b :忽略前导空格。
-R :随机排序,每次运行的结果均不同

举例说明

# sort -n -t: -k 3 1.txt 按照用户的uid进行升序排列
# sort -nr -t: -k 3 1.txt 按照用户的uid进行降序排列
# sort -n 2.txt 按照数字排序
# sort -nu 2.txt 按照数字排序并且去重
# sort -nr 2.txt
# sort -nru 2.txt
# sort -nru 2.txt
# sort -n 2.txt -o 3.txt 按照数字排序并将结果重定向到文件
# sort -R 2.txt
# sort -u 2.txt

4.uniq工具

uniq用于去除连续的重复行

常见选项:

-i: 忽略大小写
-c: 统计重复行次数
-d:只显示重复行

举例说明:

# uniq 2.txt
# uniq -d 2.txt
# uniq -dc 2.txt

5.tee工具

tee工具是从标准输入读取并写入到标准输出和文件,即:双向覆盖重定向(屏幕输出|文本输入)

选项:
-a 双向追加重定向
# echo hello world
# echo hello world|tee file1
# cat file1
# echo 999|tee -a file1
# cat file1

6.diff工具

diff工具用于逐行比较文件的不同
注意:diff描述两个文件不同的方式是告诉我们怎样改变第一个文件之后与第二个文件匹配。

语法和选项

语法:

diff [选项] 文件1 文件2

常用选项:

举例说明:
比较两个普通文件异同,文件准备:

[root@wolf ~]# cat file1
aaaa
111
hello world
222
333
bbb
[root@wolf ~]#
[root@wolf ~]# cat file2
aaa
hello
111
222
bbb
333
world

1)正常显示

diff目的:file1如何改变才能和file2匹配[root@wolf ~]# diff file1 file21c1,2 第一个文件的第1行需要改变(c=change)才能和第二个文件的第1到2行匹配< aaaa 小于号"<"表示左边文件(file1)文件内容--- ---表示分隔符> aaa 大于号">"表示右边文件(file2)文件内容> hello3d3 第一个文件的第3行删除(d=delete)后才能和第二个文件的第3行匹配< hello world5d4 第一个文件的第5行删除后才能和第二个文件的第4行匹配< 333 6a6,7 第一个文件的第6行增加(a=add)内容后才能和第二个文件的第6到7行匹配> 333 需要增加的内容在第二个文件里是333和world> world

2)上下文格式显示

[root@wolf ~]# diff -c file1 file2
前两行主要列出需要比较的文件名和文件的时间戳;文件名前面的符号***表示file1,---表示file2
*** file1 2019-04-16 16:26:05.748650262 +0800
--- file2 2019-04-16 16:26:30.470646030 +0800
*************** 我是分隔符
*** 1,6 **** 以***开头表示file1文件,1,6表示1到6行
! aaaa !表示该行需要修改才与第二个文件匹配
111
- hello world -表示需要删除该行才与第二个文件匹配
222
- 333 -表示需要删除该行才与第二个文件匹配
bbb
--- 1,7 ---- 以---开头表示file2文件,1,7表示1到7行
! aaa 表示第一个文件需要修改才与第二个文件匹配
! hello 表示第一个文件需要修改才与第二个文件匹配
111
222
bbb
+ 333 表示第一个文件需要加上该行才与第二个文件匹配
+ world 表示第一个文件需要加上该行才与第二个文件匹配

3)合并格式显示

[root@wolf ~]# diff -u file1 file2
前两行主要列出需要比较的文件名和文件的时间戳;文件名前面的符号---表示file1,+++表示file2
--- file1 2019-04-16 16:26:05.748650262 +0800
+++ file2 2019-04-16 16:26:30.470646030 +0800
@@ -1,6 +1,7 @@
-aaaa
+aaa
+hello
111
-hello world
222
-333
bbb
+333
+world

比较两个目录不同

默认情况下也会比较两个目录里相同文件的内容
[root@wolf tmp]# diff dir1 dir2
diff dir1/file1 dir2/file1
0a1
> hello
Only in dir1: file3
Only in dir2: test1如果只需要比较两个目录里文件的不同,不需要进一步比较文件内容,需要加-q选项
[root@wolf tmp]# diff -q dir1 dir2
Files dir1/file1 and dir2/file1 differ
Only in dir1: file3
Only in dir2: test1

其他小技巧:
有时候我们需要以一个文件为标准,去修改其他文件,并且修改的地方较多时,我们可以通过打补丁的方式完成。

1)先找出文件不同,然后输出到一个文件
[root@wolf ~]# diff -uN file1 file2 > file.patch
-u:上下文模式
-N:将不存在的文件当作空文件
2)将不同内容打补丁到文件
[root@wolf ~]# patch file1 file.patch
patching file file1
3)测试验证
[root@wolf ~]# diff file1 file2
[root@wolf ~]#

7. paste工具

paste工具用于合并文件行

常用选项:
-d:自定义间隔符,默认是tab
-s:串行处理,非并行

8. tr工具

tr用于字符转换,替换和删除;主要用于删除文件中控制字符或进行字符转换
语法和选项
语法:

用法1:命令的执行结果交给tr处理,其中string1用于查询,string2用于转换处理
# commands|tr 'string1' 'string2'
用法2:tr处理的内容来自文件,记住要使用"<"标准输入
# tr 'string1' 'string2' < filename
用法3:匹配string1进行相应操作,如删除操作
# tr options 'string1' < filename

常用选项:

-d 删除字符串1中所有输入字符。
-s 删除所有重复出现字符序列,只保留第一个;即将重复出现字符串压缩为一个字符串

常匹配字符串:

举例说明:

[root@wolf shell01]# cat 3.txt 自己创建该文件用于测试
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
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
boss02:x:516:511::/home/boss02:/bin/bash
vip:x:517:517::/home/vip:/bin/bash
stu1:x:518:518::/home/stu1:/bin/bash
mailnull:x:47:47::/var/spool/mqueue:/sbin/nologin
smmsp:x:51:51::/var/spool/mqueue:/sbin/nologin
aaaaaaaaaaaaaaaaaaaa
bbbbbb111111122222222222233333333cccccccc
hello world 888
666
777
999
# tr -d '[:/]' < 3.txt 删除文件中的:和/
# cat 3.txt |tr -d '[:/]' 删除文件中的:和/
# tr '[0-9]' '@' < 3.txt 将文件中的数字替换为@符号
# tr '[a-z]' '[A-Z]' < 3.txt 将文件中的小写字母替换成大写字母
# tr -s '[a-z]' < 3.txt 匹配小写字母并将重复的压缩为一个
# tr -s '[a-z0-9]' < 3.txt 匹配小写字母和数字并将重复的压缩为一个
# tr -d '[:digit:]' < 3.txt 删除文件中的数字
# tr -d '[:blank:]' < 3.txt 删除水平空白
# tr -d '[:space:]' < 3.txt 删除所有水平和垂直空白

二、bash的特性

1 、常用的通配符

*: 匹配0或多个任意字符
?: 匹配任意单个字符
[list]: 匹配[list]中的任意单个字符,或者一组单个字符 [a-z]
[!list]: 匹配除list中的任意单个字符
{string1,string2,...}:匹配string1,string2或更多字符串
# rm -f file*
# cp *.conf /dir1
# touch file{1..5}

2、bash中的引号(重点)

  • 双引号" " :会把引号的内容当成整体来看待,允许通过$符号引用其他变量值
  • 单引号’ ’ :会把引号的内容当成整体来看待,禁止引用其他变量值,shell中特殊符号都被视为普通字符
  • 反撇号`` :反撇号和$()一样,引号或括号里的命令会优先执行,如果存在嵌套,反撇号不能用
[root@wolf dir1]# echo "$(hostname)"
server
[root@wolf dir1]# echo '$(hostname)'
$(hostname)
[root@wolf dir1]# echo "hello world"
hello world
[root@wolf dir1]# echo 'hello world'
hello world
[root@wolf dir1]# echo $(date +%F)
2018-11-22
[root@wolf dir1]# echo `echo $(date +%F)`
2018-11-22
[root@wolf dir1]# echo `date +%F`
2018-11-22
[root@wolf dir1]# echo `echo `date +%F``
date +%F
[root@wolf dir1]# echo $(echo `date +%F`)
2018-11-22

shell之常用工具的使用相关推荐

  1. shell bash常用工具教程(curl,jq)

    全栈工程师开发手册 (作者:栾鹏) 架构系列文章 curl curl -h来查看请求参数的含义 -v 显示请求的信息 -X 选项指定其它协议 get:curl -v 192.168.33.1:8080 ...

  2. 西湖大学鞠峰组:环境宏病毒组学分析思路与常用工具

    环境宏病毒组学分析思路与常用工具 袁凌1, 2,倪艳4,鞠峰1, 2, 3 * 1 浙江省海岸带环境与资源研究重点实验室,工学院, 西湖大学, 杭州, 浙江 2  前沿技术研究所, 浙江西湖高等研究院 ...

  3. linux shell find depth,搞定 Linux Shell 文本处理工具,看完这篇集锦就够了

    原标题:搞定 Linux Shell 文本处理工具,看完这篇集锦就够了 Linux Shell是一种基本功,由于怪异的语法加之较差的可读性,通常被Python等脚本代替.既然是基本功,那就需要掌握,毕 ...

  4. 【shell】常用语法 -b file -c file -f file-d file -x file

    [shell]常用语法 -b file  -c file  -f file-d file  -x file      一.test条件判断 1,test文件测试: -b file     若文件存在且 ...

  5. Android Framework常用工具及LOG调试方法

    概述 Framework开发是一项非常繁琐复杂的工作,需要阅读大量的源代码,分析及其多的LOG信息来定位错误位置.这个时候如果使用一些工具或者知道如何定位重要LOG信息,就可以使一些复杂的工作变的简单 ...

  6. 【算法竞赛学习】数字中国创新大赛智慧海洋建设-Task1地理数据分析常用工具

    智慧海洋建设-Task1 地理数据分析常用工具 在地理空间数据分析中,常会用到许多地理分析的工具,在本模块中主要是针对常用的shapely.geopandas.folium.kepler.gl.geo ...

  7. SSH客户端常用工具SecureCRT操作

    SSH客户端常用工具SecureCRT操作 1.1 SecureCRT工具介绍 SecureCRT是一款支持SSH(SSH1和SSH2)协议的终端仿真软件,常被用来运行于Windows下远程登录UNI ...

  8. 细聊MySQL之常用工具及基本操作(完)

    细聊MySQL之常用工具及基本操作(一) 细聊MySQL之常用工具及基本操作(二) 细聊MySQL之常用工具及基本操作(三) 细聊MySQL之常用工具及基本操作(完) 十.binlog查看工具mysq ...

  9. 《Linux编程》学习笔记 ·002【Linux常用工具GCC、GDB、Make】

    注:前言.目录见 https://blog.csdn.net/qq_44220418/article/details/108428971 文章目录 一.GCC编译器 1.GCC编译程序的流程 2.GC ...

最新文章

  1. 用Beamer制作幻灯片(卷二 色彩篇)
  2. 首部网络支付风险防范自律规范出台
  3. 【Android】开发优化之——调优工具:TrackView,Method Profiling
  4. 什么是软件危机?产生原因?如何解决?
  5. html scale方法的作用,HTML Canvas scale() 方法
  6. [zz]写在KVM (Kernel-based Virtual Machine) 安装成功后
  7. 0113——代理模式
  8. 使用Caffe框架训练模型
  9. win10系统进行电脑分盘
  10. 优启通制作系统u盘_EasyU优启通U盘启动盘制作工具BIOS+UEFI双启无捆绑
  11. TOM邮箱的全新域名,163vip.com、163vip.net,老朋友的新问候!
  12. 《德鲁克管理思想精要》读书笔记3 - 管理的新范式?
  13. Oracle 数据库12c 新特性总结
  14. 【android】项目案例(一)之超级课程表
  15. Your hostname, xxx resolves to a loopback address: 127.0.1.1; using x.x.x.x instead(on interface xx)
  16. 磁力链接 结构解析 分享
  17. hj118888.com162287l9999提出的mysql索引问题
  18. 跨平台应用程序开发方法大盘点
  19. 非接触式射频读卡器 M1读卡,支持USB,ISO14443A/B,可读二代证ID
  20. myeclipse10激活注册码生成器代码

热门文章

  1. 手机照片导入电脑步骤_怎样把手机里的照片传到电脑里
  2. BAT Window批量重命名
  3. Jlink-V9详细制作材料(带串口+SW)----小白的福音
  4. 如何将低压精密运算放大器的性能扩展到高压高侧电流检测应用(高电流电阻采集电压电路图及误差分析)
  5. 26.删除排序数组中的重复项
  6. 158.5. manifests
  7. 《数字短片创作(修订版)》——第一部分 剧本创作 第1章 数字短片创意技法 剧本创作的构思...
  8. 通过经度纬度得到距离
  9. POJ - 1741 Tree(点分治模板题)
  10. 中石油训练赛 - Match Matching(完全背包)