Linux -- 文件统计常用命令
标签(空格分隔): Linux
sort -- 文件内排序命令
sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次比较其ASCII码。
- 按每行升序排序:
sort seq.txt
- 在输出行中去除重复行:
sort -u seq.txt
- 输出行按降序排序:
sort -r seq.txt
- 将输出结果重定向写入新的文件:
sort seq.txt > seq1.txt
- 将输出结果重定向写入原来文件:
sort seq.txt -o seq.txt
- 输出结果以数值而非ASCII码排序:
sort -n seq.txt
- 按照指定列排序:
sort -t ':' -k 2, 2nb seq.txt
-t
指定分隔符,-k
指定按照哪一列排序如果分隔符为制表符,则使用
-t $'\t'
- 稳定排序:
sort -s seq.txt
- 合并多个有序文件
sort -m seq.txt seq1.txt
uniq
对于连续重复出现的行,只会打印第一行,而不会打印其他重复行。与sort连用。
- 一般用法:
uniq seq.txt
- 打印出每行重复出现的次数:
uniq -c seq.txt
- 打印出出现多次(大于1次)的行:
uniq -d seq.txt
- 打印不存在重复行的行:
uniq -u seq.txt
- 忽略掉前n个域:(忽略掉前n个域,将第(n+1)以及之后的域当做关键字)
uniq -f n seq.txt
- 忽略掉前n个字符:
uniq -s n seq.txt
- 忽略掉前n个域和前m个字符:
uniq -f n -s m seq.txt
- d最多比较n个字符:
uniq -w n seq.txt
cut
cut命令用于打印出一个文件中指定的某几个域,或某几个字符,或某几个字节。
按字节打印
- 打印每行的第n个字节:
cut -b n seq.txt
- 打印每行的第1-n这个范围的字节:
cut -b -n seq.txt
- 打印每行的第n-最后范围的字节:
cut -b n- seq.txt
- 打印每行的第m-n这个范围的字节:
cut -b m-n seq.txt
- 打印多个范围的字节:
cut -b m-n,t-s seq.txt
按字符打印
- 打印每行的第n个字符:
cut -c n seq.txt
剩下的情况如按字节打印。
按域打印
cut 命令默认以制表符为一个分隔符。如果要自定义分隔符,用-d
指定。cut -d '分隔符'
- 打印每行的第n个域:
cut -d '分隔符' -f n seq.txt
paste
paste命令用来将多个文件中的内容并列打印,或横排打印。每行有多个域,每个域对应一个文件中相应行的内容。任意两个域之间默认用一个制表符隔开。如果某一行中,某个文件没有内容,则相应域为一个空串。
- 一般语法:
paste filename1 filename2 filename3
- 指定分隔符:
paste -d '分割符' filename1 filename2 filename3
- 横排打印:(先打印完一个文件中的所有行到一行中,再打印另外一个文件中的所有行到下一行)
paste -s -d '分隔符' filename1 filename2 filename3
split
split命令用来将一个文件按字节或者按行分割成多个小文件。
- 按字节分割成多个文件:
split -b m -a p -d --additional-suffix='额外的后缀字符串' filename output
-b
指定字节数,可以带单位,如K, M, G, T, P, E, Z, Y
;-a
指定分割成的子文件的文件名的后缀长度。默认情况下后缀为[a-z]的字符串。-d
指定后缀名为数字字符串,比如长度为2的数字字符串后缀为00,01,02...-additional-suffix
指定额外的字符串;- output 为所分割成的子文件的文件名的前缀。
- 按行数分割成多个文件:
split -l m -a p -d --additional-suffix='额外的字符串' filename output
- 如:
aplit -l 2 -a 2 seq.txt output
cat
将多个文件连接在一起并打印。一个文件连接到前一个文件的尾部。
- 一般语法:
cat filename1 filename2 filename3
- 显示行号:
cat -n filename1 filename2 filename3
join
- 左连接:
join -a 1 -t '分隔符' -1 m -2 n filename1 filename2
-a
指定文件编号(只能为1或者2)。命令行中第一个文件的编号为1,第二个文件的编号为2.- 如果不指定,则表示进行内连接。只会打印出匹配并合并后的行;
- 如果指定为1,则表示进行左连接;
- 如果指定为2,则表示进行右连接。
- 如果既指定为1,又指定为2,则表示进行全连接。除了会打印出两个文件中匹配并合并后的行外,还会打印出第一个文件和第二个文件中不匹配的行。
-1
是参数,用于指定需要进行匹配的第一个文件中的域的编号;-2
是参数,用于指定需要进行匹配的第二个文件中的域的编号。- 在打印合并后的内容的过程中,会先打印匹配的域,然后分别打印第一个文件和第二个文件中的剩余部分
- 右连接:
join -a 2 -t ':' -1 1 -2 1 seq.txt seq1.txt
- 全连接:
join -a 1 -a 2 -t ':' -1 1 -2 1 seq.txt seq1.txt
- 内连接:
join -1 1 -2 1 seq.txt seq1.txt
Linux -- 文件统计常用命令的更多相关文章
- Linux文件操作常用命令整理
收集.整理日常系统管理或维护当中的,常用到的一些关于文件操作的命令或需求,后续会慢慢补充.完善! 查看.生成指定目录的目录树结构? [root@DB-Server ~]#tree #当前目录 ...
- linux 文件相关常用命令
文件或者目录操控命令 1,cd切换目录. 其中- 代表前一个目录 2,mkdir 新建目录. 加上-p参数可以递归创建多级目录 mkdir -p test1/test2/test3 3,rmdir删除 ...
- Linux文件操作常用命令
一.一些文件操作命令. 1.cd /home 进入"home目录" 2.cd ../ 返回上一级目录 3.cd - 返回上次所在的目录 4.pwd 显示工程路径 5.ll 显示 ...
- linux:终端常用命令 + vi命令修改文件及保存 方法
首先介绍一下Ubuntu下各个目录的一般作用: / 这就是根目录,一台电脑有且只有一个根目录,所有的文件都是从这里开始的.举个例子:当你在终端里输入“/home”,你其实是在告诉电脑,先从/(根目录 ...
- Linux查看系统配置常用命令
Linux查看系统配置常用命令: 系统 # uname -a # 查看内核/操作系统/CPU信息# head -n 1 /etc/issue # 查看操作系统版本# cat /proc/cpuinfo ...
- linux vi编辑常用命令
linux vi编辑常用命令 来源:互联网 作者:佚名 时间:07-10 21:31:14 [大 中 小] linux vi编辑常用命令,需要的朋友可以参考下 vi编辑器中有三种状态模式 1. ...
- Linux 系统巡检常用命令
Linux系统巡检常用命令 # uname -a # 查看内核/操作系统# cat /etc/centos-release # 查看centos操作系统版本# cat /proc/cpuinfo ...
- linux 下 mysql 常用命令
linux 下 mysql 常用命令 阅读目录 ====================== 1.开启和关闭 1.1.开启 1.2.关闭 1.3.重启 2.登录 2.1.密码明文 2.2.密码密文 ...
- Linux学习之CentOS(二)--初识linux的一些常用命令
Linux学习之CentOS(二)--初识linux的一些常用命令 在VM上安装完了CentOS6.4以后,看着linux系统成功跑起来,心里小激动了一把......但是前方学习的道路还很遥远... ...
随机推荐
- NLP 自然语言处理
参考: 自然语言处理怎么最快入门:http://www.zhihu.com/question/ 自然语言处理简介:http://wenku.baidu.com/link?url=W6Mw1f-XN8s ...
- Openfire 的安装和配置
1. 下载最新的openfire安装文件 官方下载站点:http://www.igniterealtime.org/downloads/index.jsp#openfire 下载地址: Exe:htt ...
- Linux vi编辑器的基本命令
vi编辑器的文字说明 模式:命令模式,编辑模式,末行模式. 切换方式:命令模式→i→编辑模式,编辑模式→Esc→命令模式,命令模式→:→末行模式. 功能: 命令模式(Command Mode): 控制 ...
- [troubleshoot][archlinux][X] GPU HANG
前言:如下内容已经是在hang完大概半个多月后了,当时想写,一直没过来写,写blog果然也是已经花费时间的事情. 最近一直在休假,电脑的使用频率也不多.后来还是为了生活,不情愿的去开始上班了,上班的第 ...
- python 多线程就这么简单(续)
之前讲了多线程的一篇博客,感觉讲的意犹未尽,其实,多线程非常有意思.因为我们在使用电脑的过程中无时无刻都在多进程和多线程.我们可以接着之前的例子继续讲.请先看我的上一篇博客. python 多线程就这 ...
- 多进程、协程、事件驱动及select poll epoll
目录 -多线程使用场景 -多进程 --简单的一个多进程例子 --进程间数据的交互实现方法 ---通过Queues和Pipe可以实现进程间数据的传递,但是不能实现数据的共享 ---Queues ---P ...
- LuaXMLRPC笔记
XMLRPC XMLRPC 为以http为传输协议,使用xml格式化数据来执行远程过程调用, 区别于本地过程调用, 即发生在不同主机之间. 属于分布式计算的一种简单实现,比web service简单易 ...
- 对hashmap与hashcode()、equals()的理解
1.equals方法没被重写的时候 比较的只是对象的地址 重写之后 比较的才是对象里的内容 2.重写equals的时候 务必需要重写hashcode 不然在用到容器的时候 会出现问题 因为容器会 ...
- linux 下查看系统资源和负载,以及性能监控
1,查看磁盘 df -h 2,查看内存大小 free free [-m|g]按MB,GB显示内存 vmstat 3,查看cpu cat /proc/cpuinfo 只看 ...
- linux 查看磁盘剩余命令
df -hl命令查看各磁盘的大小,使用情况,挂载点等信息. du -bs dir_name查看具体目录的空间大小