shell特殊符号cut命令 sort_wc_uniq命令 tee_tr_split命令 shell特殊符号
shell特殊符号cut命令
特殊符号
* 通配符,任意个任意字符
? 任意一个字符
# 注释字符
\ 脱义字符
c=\$a\$b
echo $c
| 管道符
cat 1.txt |less
cat 1.txt |more
cut 截取字符串
显示头2行
cat /etc/passwd |head -2
切割":"第一段 cut -d ":" -f 1
切割两断:cut -d ":" -f 1,2
把etc/passwd 下前两行,以冒号切割1到三段
cat /etc/passwd |head -2 |cut -d ":" -f 1-3
root@localhost:~# cat /etc/passwd |head -2 |cut -d ":" -f 1,2
root:x
bin:x
root@localhost:~# cat /etc/passwd |head -2 |cut -d ":" -f 1-2
root:x
bin:x
root@localhost:~# cat /etc/passwd |head -2 |cut -d ":" -f 1-3
root:x:0
bin:x:1
cut 指定第几个字符:
cut -c 4
root@localhost:~# cat /etc/passwd |head -2 |cut -c 4
t
:
sort_wc_uniq命令
sort 排序 -n 以数字排序 -r 反序
sort /etc/passwd 按照首字母排序
取文件内容前10行写到1.txt
head /etc/passwd > 1.txt
vim 1.txt 编辑,写入几个特殊符号 * 《》 <>?
sort 1.txt
默认是特殊符号排在前面,然后是数字,字母先后顺序,*号排在后面
sort -n 1.txt
会以数字排序,字母和特殊符号会认为是0
sort -nr 1.txt 反序排序 最大的在前面
sort -t -kn1/-kn2 分隔符 指定第几段排序
wc -l 统计行数
wc -m 统计字符数
root@localhost:~# wc -l 1.txt
19 1.txt
root@localhost:~# wc -m 1.txt
432 1.txt
root@localhost:~# vim 2.txt
输入
abc
123
:wq
root@localhost:~# wc -m 2.txt
8 2.txt
root@localhost:~# cat -A 2.txt
abc$
123$
每一行都有一个换行符 $
wc -w 2.txt 统计单词数,是以空白字符区分的
root@localhost:~# wc -w 2.txt
2 2.txt
uniq (unique) 2.txt 去重复
root@localhost:~# uniq 3.txt
1
222
333
4
56476
root@localhost:~# cat 3.txt
1
1
1
222
333
4
4
56476
先排序,再统计。
统计出现重复的次数:
sort 2.txt |uniq -c
root@localhost:~# sort 3.txt |uniq -c
3 1
1 222
1 333
2 4
1 56476
tee_tr_split命令
管道|tee 和>类似,重定向的同时还在屏幕上显示
作用: 重定向并打印到屏幕上
root@localhost:~# sort 3.txt |uniq -c > a.txt
root@localhost:~# cat a.txt
3 1
1 222
1 333
2 4
1 56476
root@localhost:~# sort 3.txt |uniq -c |tee b.txt
3 1
1 222
1 333
2 4
1 56476
root@localhost:~# cat b.txt
3 1
1 222
1 333
2 4
1 56476
root@localhost:~#
">" 与 “|tee”都可以写入文件
清空a.txt
>a.txt
>>追加 ,|tee -a 也可以追加
|tee -a 追加
root@localhost:~# sort 3.txt |uniq -c |tee -a b.txt
tr替换字符,tr ‘a’'b', 大小写替换tr'[a-z]' ‘[A-Z]’
把xb改成大写的XB
root@localhost:~# echo "xiaobo" |tr '[xb]' '[XB]'
XiaoBo
单独把x改成X
root@localhost:~# echo "xiaobo" |tr 'x' 'X'
Xiaobo
把小写字母改成大写字母
root@localhost:~# echo "xiaobo" |tr '[a-z]' '[A-Z]'
XIAOBO
把所有的字母改成1
root@localhost:~# echo "xiaobo" |tr '[a-z]' '1'
111111
当日志文件800G的话,读取困难,可以切割
把etc下所有conf文件追加到a.txt文件里去
root@localhost:~# find /etc/ -type f -name "*conf" -exec cat {} >> a.txt \;
root@localhost:~# du -sh a.txt
1.1M a.txt
切割文件a.txt ,每个文件100K
root@localhost:~# du -sh a.txt
464K a.txt
root@localhost:~# split -b 100k a.txt
root@localhost:~# ls
a.txt xaa xab xac xad xae
指定文件名前缀
root@localhost:~# rm -f x*
root@localhost:~# split -b 100K a.txt abc
root@localhost:~# ls
abcaa abcab abcac abcad abcae a.txt
切割每1000行一个文件
root@localhost:~# split -l 1000 a.txt
root@localhost:~# ls
a.txt xaa xab xac xad xae xaf xag xah xai xaj xak xal xam
root@localhost:~# wc -l a.txt
12764 a.txt
shell特殊符号
$ 变量前缀,!$组合,正则里面表示行尾
; 多条命令写到一行,用分号分割
~用户家目录,后面正则表达式表示匹配符
&放到命令后面,会把命令丢到后台
写入重定向> , 追加重定向>> &>(错误重定向和正确 重定向输出)
[] 指定字符中的一个,[0-9],[a-zA-Z],[ABC]
|| 和 &&,用于命令之间
[root@localhost ~]# for i in `seq 1 10`
> do
> echo $i
> done
1
2
3
4
5
6
7
8
9
10
多条命令用分号分割
[root@localhost ~]# for i in `seq 1 10`;do echo $i ; done;
1
2
3
4
5
6
7
8
9
10
|| 表示或,如果前面的命令执行成功,后面的命令不执行;如果前面的命令执行不成功,继续执行后面的命令
[root@localhost ~]# ls la.txt||wc -l 1.txt
ls: 无法访问la.txt: 没有那个文件或目录
0 1.txt
[root@localhost ~]# wc -l 1.txt ||ls la.txt
0 1.txt
&& 如果前面的命令成功,就会执行后面的命令;如果前面的命令执行失败,就不会执行后面的命令。
有假就不会执行后面的。
[root@localhost ~]# ls la.txt && wc -l 1.txt
ls: 无法访问la.txt: 没有那个文件或目录
[root@localhost ~]# wc -l 1.txt && ls la.txt
0 1.txt
ls: 无法访问la.txt: 没有那个文件或目录
判断目录是否存在
[-d xiaobo] || mkdir xiaobo
如果xiaobo目录不存在,就会创建目录。
如果目录存在,就不会创建目录。
shell特殊符号cut命令 sort_wc_uniq命令 tee_tr_split命令 shell特殊符号的更多相关文章
- shell特殊符号及cut、sort_wc_uniq、tee_tr_split命令 使用介绍
第6周第2次课(4月24日) 课程内容: 8.10 shell特殊符号cut命令8.11 sort_wc_uniq命令8.12 tee_tr_split命令8.13 shell特殊符号下 扩展1. s ...
- 特殊符号 sort_wc_uniq命令 tee_tr_split命令
* 任意个 任意字符 ? 任意一个字符 # 注释字符 \ 转意符 | 管道符 (之前有说过) cut 命令: cut -d "&quo ...
- 【Linux命令】文本文件编辑命令10个(cat、more、less、head、tail、tr、wc、stat、cut、diff)
目录 cat查看文档 more可分页查看文档 less相比较more功能更强大 head查看文档的前N行 tail查看文档的后N行或试试刷新查看 tr替换文本字符 wc统计文本行数 stat查看文档存 ...
- linux shell 管道命令(pipe)使用及与shell重定向区别
管道命令操作符是:”|”,它仅能处理经由前面一个指令传出的正确输出信息,也就是 standard output 的信息,对于 stdandarderror 信息没有直接处理能力.然后,传递给下一个命令 ...
- shell中的内建命令, 函数和外部命令
转自shell中的内建命令, 函数和外部命令 Shell识别三种基本命令:内建命令.Shell函数以及外部命令: (1)内建命令就是由Shell本身所执行的命令. 有些命令是由于其必要性才内建的 ...
- sed命令详解 vim高级技巧 shell编程上
第1章 sed命令详解 1.1 查找固定的某一行 1.1.1 awk命令方法 [root@znix ~]# awk '!/oldboy/' person.txt 102,zhangyao,CTO 10 ...
- Shell编程(脚本)的经常使用命令和语句
一些经常使用的Shell编程(脚本)命令和语句,能够满足一般需求. 接收到的命令參数: 參数个数: $# 參数值: 命令本身:$0 第一个參数:$1 第二个參数:$2 -- 退出命令: exit ec ...
- 【转】shell中的内建命令, 函数和外部命令
原文:http://www.cnblogs.com/xkfz007/archive/2011/10/13/2209571.html linux命令有内部命令和外部命令之分.内部命令实际上是shell程 ...
- shell编程之算术扩展(引号、命令替换、算术扩展)
1.单引号 .双引号.反引号的区别 单引号:忽略所有特殊字符 双引号:忽略大部分特殊字符($ `等字符除外) [root@tlinux shell]# echo '*' * [root@tlinux ...
随机推荐
- tf.placeholder
tf.placeholder placeholder( dtype, shape=None, name=None ) 功能说明: 是一种占位符,在执行时候需要为其提供数据 参数列表: 参数名 必选 类 ...
- 主流Java数据库连接池分析(C3P0,DBCP,TomcatPool,BoneCP,Druid)
主流数据库连接池 常用的主流开源数据库连接池有C3P0.DBCP.Tomcat Jdbc Pool.BoneCP.Druid等 C3p0: 开源的JDBC连接池,实现了数据源和JNDI绑定,支持JDB ...
- 基于jQuery全屏相册插件zoomVisualizer
基于jQuery全屏相册插件zoomVisualizer.这是一款基于jquery ui实现的相册插件,支持隐藏显示相册缩略图,支持左右箭头切换图片,支持放大缩及缩小图片.效果图如下: 在线预览 ...
- spring mvc之启动过程源码分析
简介 这两个星期都在看spring mvc源码,看来看去还是还是很多细节没了解清楚,在这里把看明白的记录下,欢迎在评论中一起讨论. 一.铺垫 spring mvc是基于servlet的,在正式分析之前 ...
- Where-To-Put-The-Auto-Layout-Code(AutoLayout代码应该放在哪里?)
Where-To-Put-The-Auto-Layout-Codehtml, body {overflow-x: initial !important;}html { font-size: 14px; ...
- [Timer]应用层实现sleep
转自:https://www.cnblogs.com/longbiao831/p/4556246.html Select只能做延时,可以做回调吗? 本文讲述如何使用select实现超级时钟.使用sel ...
- Android——Fragment 真正的完全解析(下)(转)
原文地址:http://blog.csdn.net/lmj623565791/article/details/37992017 上篇博客中已经介绍了Fragment产生原因,以及一些基本的用法和各种A ...
- AR2220 通过cpu-defend policy处理大量大量arp广播的小技巧
今天发现有局域网里面有几台电脑中毒了,在大量的发送ARP报文,导致设备cpu利用率很高. 一.查看display cpu-defend statistics 发现arp-reply arp-requ ...
- redis获取当前时间精确到微秒
在redis取得当前时的方法为执行time命令 127.0.0.1:6382> time1) "1495780564"2) "894089" 第一行为以 ...
- 【Python】 linecache模块读取文件
[linecache] 过往在读取文件的时候,我们通常使用的是这种模式: with open('file.txt','r') as f: line = f.readline() while line: ...