小课2:筛选信息命令

Posted 福大大架构师每日一题

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小课2:筛选信息命令相关的知识,希望对你有一定的参考价值。

1 shell简介

1.1 核心命令回顾

1.1.1 筛选信息

学习目标

这一节,我们从 shell快捷键、grep、sort、小结、四个方面来学习。

shell快捷键

快捷键符号

命令执行:	
    !! 					执行上一条命令
    !num 				执行历史命令中的第num行命令
    Ctrl 关键字 		  执行内容匹配的命令


ctrl+r后,然后输入red,出现cat /etc/redhat-release命令,敲回车。

命令行切换
	Ctrl + A 			光标迅速回到行首
	Ctrl + E			光标迅速回到行尾
	Esc + b				移动到当前单词的开头
	Esc + f				移动到当前单词的结尾
	
	Ctrl + k			删除光标到行尾内容
	Ctrl + u			删除光标到行首内容
	Ctrl + y			粘贴删除的内容
	Ctrl + c			临时终止命令行命令

grep命令

负责从数据源中检索对应的字符串,行过滤

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



grep 高亮显示
centos7中已经为大家设置了,存放在/etc/profile.d/colorgrep.sh文件中,如若大家使用的系统中没有设置颜色输出,可以使用以下方法来自行设置

临时设置:
# 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 -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行

sort命令

信息排序

语法:
sort [options] file
将文件的每一行作为一个单位,从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出。

options:
-u :去除重复行
-r :降序排列,默认是升序
-o : 将排序结果输出到文件中  类似 重定向符号>
-n :以数字排序,默认是按字符排序
-t :分隔符
-k :第N列
-b :忽略前导空格。
-R :随机排序,每次运行的结果均不同。
文件内容
[root@localhost ~]# cat num.txt
9
8
6
8
4
7
2
1

内容升序
[root@localhost ~]# sort -n num.txt
1
2
4
6
7
8
8
9

内容降序
[root@localhost ~]# sort -r num.txt
9
9
8
7
6
4
2
1

其他实践
sort -nu num.txt				升序去重
sort -ru num.txt				降序去重
sort -nru num.txt				先升序后降序再去重
sort -R num.txt					随机排序
sort -nu num.txt -o /tmp/a.txt	升序去重后输出到一个文件





以上是关于小课2:筛选信息命令的主要内容,如果未能解决你的问题,请参考以下文章

mysql 排序查询字段

如何在EXCEL中筛选出工资最高和最低的两个人信息

Excel实用知识2(排序,筛选,分析工具)

MySQL数据库语句

linux 中 ll 命令如何让查询结果按时间升序或降序排序?

python 字典排序