文章目录
- 一、sort命令
- 二、uniq命令
- 三、 tr命令
- 四、cut命令
- 五、split命令
- 六、paste命令
- 七、eval命令
一、sort命令
sort命令以行为单位对文件内容进行排序,也可以根据不同的数据类型来排序,比较的原则是从首字符向后,一次按ASCII码的值进行比较,最后按序输出。
ASCII码,它是American Standard Code for Information Interchange的缩写(美国标准信息交换代码),已被国际标准化组织ISO采纳,作为国际通用的信息交换标准代码。其中48~57为0到9十个阿拉伯数字。65~90为26个大写英文字母,97~122号为26个小写英文字母
语法的格式:
sort [选项] 参数
cat file | sort [选项]
选项 | 含义 |
---|---|
-n | 按照数字进行排序 |
-r | 反向排序 |
-u | 等同于uniq,表示相同的数据仅显示一行 |
-t | 指定覅段分隔符,默认使用tab键分隔 |
-k | 指定排序字段 |
-o | 输出文件名,将排序后的结果转存至指定文件 |
-f | 忽略大小写,将小写字母都转换成大写字母来比较 |
-b | 忽略每行前面的空格 |
二、uniq命令
uniq命令是用于报告或者忽略文件中连续的重复行
uniq [选项] 参数
cat file | uniq [选项]
常用选项:
选项 | 作用 |
---|---|
-c | 计算行数,并删除文件中重复的行 |
-d | 仅显示立案续重复的行 |
-u | 仅显示出现一次的行 |
三、 tr命令
tr常用来对来自标准输入的字符进行替换、压缩和删除。
tr [选项] 参数
选项 | 含义 |
---|---|
-c | 保留字符集1的字符,其他的字符用(包括换行符\n)字符集2替换 |
-d | 删除所有属于字符集1的字符 |
-s | 将重复出现的字符串压缩为一个字符串;用字符集2 替换 字符集1 |
-t | 字符集2 替换 字符集1,不加选项同结果 |
四、cut命令
显示行中的指定部分,删除文件中指定字段
格式:cut [选项] 参数
常用选项
选项 | 说明 |
---|---|
-f | 通过指定哪一个字段进行提取。cut命令使用“TAB”作为默认的字段分割符 |
-d | “TAB”是默认的分隔符,使用此选项可更改为其他的分隔符 |
–complement | 用于排除所指定的字段 |
–output-delimiter | 更改输出内容的分隔符 |
五、split命令
用于将linux下将一个大文件拆分成若干个小文件
语法格式:
split [选项] 参数 原始文件 拆分后文件名前缀
常用选项
选项 | 作用 |
---|---|
-l | 以行数来拆分 |
-b | 以大小来拆分 |
六、paste命令
按列合并文件
语法格式:paste [选项] 文件名1 文件名2
常用选项
选项 | 作用 |
---|---|
-d | 更改合并文件之中间隔符 |
-s | 可以边为横向输出 |
七、eval命令
在命令字前加上eval时,shell会在执行命令之前扫描他两次,eval命令将首先会先扫描命令行进行所有的置换,然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。
[root@localhost ~]# echo "hello world" > file
[root@localhost ~]# myfile="cat file"
[root@localhost ~]# echo $myfile
cat file
[root@localhost ~]# eval $myfile
hello world