七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

格式说明:

操作

概念

命令

说明及举例


七.cat、cut、less、head、tail、wc、sort、uniq、grep


cat

cat -A a.txt 查看隐藏内容
cat -n a.txt 显示行号
cat -s a.txt 压缩空行,把多行空行压缩为一行
tac a.txt 反着显示文件内容(反写命令cat)
rev a.txt 文件中每行的内容反向显示
cat f1 f2 合并f1 f2 内容

more 分页显示

more -d a.txt 空格翻页,回车一行行看

less

可以往回翻页,n往下翻页,N往上翻页, /+内容搜索

head

默认显示文件前十行

head -n 30 file 显示文件前30行

tail

默认显示文件后10行

tail -n30 file 显示文件后30行
tail -n20 -f file 动态显示文件后20行
tail -n0-f f1 & 后台运行,有新变化时候显示
jobs 查看后台运行的程序
fg 1 
ctrl c结束

cut 从文件中取部分内容,取列

cut -d: -f1,3,5-7 file 分隔符为:取文件中第1,3,5-7列内容
cut -c1-2 file 取文件1-2个字符数
getent passwd|cut -d: -f1-3 --output-delimiter=* 分隔符替代为*

paste

paste -d: f1 f2 把f1 f2 文件内容按行合并,以:分隔

wc 文本数据统计

wc f1 显示文件f1有多少行、单词、字符
wc -l f1 只统计行
wc +输入 ctrl+d结束,统计输入的数据

sort 文本排序

sort -t: -k 3 -nru /etc/passwd 以:为分隔符对第三列进行倒序数字大小排序并合并重复

echo 最大使用率为:df|cut -c 44-47|sort -n|tail -2|head -1

uniq 从输入中删除重负的前后相接的行

uniq -c f2 显示每行重复出现的次数
-d 仅显示重复行
-u 仅显示不重复的行

diff 比较两个文件的不同

diff -u f1 f11 >diff.log 比较两个文件并把结果存到diff.log中
删除f11后
patch -b f1 diff.log 恢复f11名称为f1 并把原有f1重命名

looger "this is a test log"

ps axo user.ruser.group,rgroup.cmd 看进程有效用户,真正发起的用户,有效组,真正执行的组,执行的命令


netstat -tn 查看链接

grep 文本过滤

主要功能:从文本中过滤出特定的行 grep 支持正则表达式 egrep 支持扩展的正则表达式 fgrep 不支持正则表达式(速度快)

grep root /etc/passwd 从passwd文件中搜索带root的行并打印
grep -n -A3 root /etc/passwd显示匹配行及其后的3行
grep -n -B3 root /etc/passwd显示匹配行及之前的3行
grep -n -C3 root /etc/passwd显示匹配行及其前后的3行
grep -n -C3 -e root -e home /etc/passwd显示包含root或home的行及其前后的3行
grep "$USER" /etc/passwd
-v 显示与搜索条件不匹配的行
-i 忽略大小写
-n 显示匹配的行号
-c 统计匹配的行数
-o 只显示匹配到的字符串
-q 静默模式
echo &? 显示上一个命令是否执行成功,成功显示0
-e 或者 -e root -e home 包括root或者home
-w 单行单词过滤
-E

正则表达式

元字符分类:字符匹配、匹配次数、位置锚定、分组

字符匹配

. 匹配任意单个字符

grep r..t /etc/passwd

[] 匹配指定范围内的任意单个字符

grep r[a-Z][a-Z]t /etc/passwd

[^]匹配指定范围外的任意单个字符

匹配次数(看右边,左边有转译)

* 匹配前面的字符任意次,包括0次

ro*t rot roooot

\?匹配前面的字符0次或者1次

grep "ro\?t" /etc/passwd

\+ 匹配前面的字符1次以上

\{17\}匹配前面的字符17次

\{1,19\}匹配前面的字符1到19次之内

grep "ro{1,19\}t" /etc/passwd

\{,16\}匹配前面的字符最多16次

\{18,\}匹配前面的字符最少18次

位置锚定 定位出现的位置

^表示行首

grep ^root /etc/passwd 搜出以root开头的行

$表示行尾

grep root$ /etc/passwd 搜出以root结尾的行
grep ^root.bash$ /etc/passwd 搜出以root开头以bash结尾的行 
grep "^$" /etc/passwd 搜出空行
grep -v "^$" /etc/passwd 搜出非空行
grep -v "^[[:space:]]
$" /etc/passwd 搜出非空行,包括空格

\<\ >用于单词的锚定 分开就是词首\<和词尾\>

grep "\<root>" /etc/passwd 搜出包含整个root单词的行

\b可以锚定词首或词尾

分组

\(root\)\+ 表示root单词重复1次以上
grep "\(r.t).*\(r..t).*\1" f1 这句话代表第一个分组(r.t)的匹配结果中的第一个,到\1的一段内容都符合的行,假如(r.t)的结果是rat,那么\1的结果也是rat,最后的结果就是筛选出包含类似结果为"rat…raat..rat"的行,如果是\1换成\2,则是匹配(r..t)的

总结:

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

练习:
1.cat /proc/meminfo |grep -i ^s (grep -i ^s /proc/meminfo)
2.cat /etc/passwd|grep -v "/bin/bash"$ (grep -v "/bin/bash"$ /etc/passwd)
3. cat /etc/passwd|grep '^rpc\b'|cut -d: -f7 (grep '^rpc\b'|cut -d: -f7|cut -d: -f7)
4. grep "\<[[:digit:]]{2,3}>" /etc/passwd
5. grep "^[[:space:]]+[^[:space:]]." /testdir/f1
6. netstat -tan|grep "\bLISTEN[[:space:]]
$" 
7. 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

egrep 扩展正则表达式

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep 重复多次o,不用加\了

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

练习:
1.grep -E "^(root|mage|wang)\b" /etc/passwd|cut -d: -f1,3,7
2.grep -E "^([[:alpha:]_])+().*" /etc/rc.d/init.d/functions
3.

/etc/rc.d/init.d/functions

正则表达式表示ip 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

正则表达式表示手机号

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

邮箱 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

sed 文本编辑工具

awk 文本报告生成器

原创文章,作者:自己泡面,如若转载,请注明出处:http://www.178linux.com/39191

(0)
自己泡面自己泡面
上一篇 2016-08-24 10:13
下一篇 2016-08-24 10:13

相关推荐

  • Linux文件的权限与解析

    一,文件的基本权限: 通常,你使用ls -l 命令,就会看到这样的行:   让我们解析一下这些字段代表的意思: -rw-r–r–. 1 root root 1018 Nov 6 2016 usb_modeswitch.conf 文件类型权限  硬链接数 文件所有者 文件所属组 文件容量  文件最后被修改时…

    2017-07-30
  • 如何实现在命令行输入pwd时显示出ifconfig的效果

    1、使用type ifconfig 查看   2、使用type pwd 查看 如果还没有使用过pwd则显示如下,表示pwd属于内部命令,然后输入enable -n pwd 禁用这个内部命令   如果已经使用过,就会显示hash,已经缓存过   此时就不仅需要禁用内部命令,还需要使用hash -d pwd 清除pwd的缓存,使其在…

    2017-07-13
  • N25第二周作业

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。     (1).cat:cat命令可以用来合并文件,也可以用来在屏幕上显示整个文件的内容。     2.语法:cat [选项] [文件]…     3.选项: &nbsp…

    Linux干货 2016-12-26
  • 使用NFS和Samba文件服务搭建博客站点

    使用NFS和Samba文件服务搭建博客站点 实验目的:分别使用NFS和Smaba文件服务实现wordpress 实验要求: (1) server导出/data/application/web,在目录中提供wordpress; (2) client挂载nfs server导出的文件系统至/var/www/html;(3) 客户端1(lamp),部署w…

    2017-04-30
  • Linux Service and Security(Part 1)

    一、知识整理 1、不安全的传统协议: telnet、FTP、POP3等:不安全的密码; http、smtp、NFS等:不安全信息; Ldap、NIS、rsh等:不安全验证。 设计基本原则: 使用成熟的安全系统; 以小人之心度输入数据; 外部系统是不安全的; 最小授权; 减少外部接口; 缺省使用安全模式; 在入口处检查; 安全不是似是而非; 从管理上保护好系统…

    Linux干货 2016-10-09
  • 第九周脚本练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; awk -F: ‘{if($NF!=”/sbin/nologin”) print $1}’ /etc/passwd | wc -l 2、写一个脚本 (1) 获取当前主机的主机名,保存于ho…

    Linux干货 2017-03-30