linuxsort linux sort命令参数及用法详解
你是否想了解更多关于linuxsort和linux sort命令参数及用法详解的知识?在本文中,小编将为您详细介绍这两个话题,帮助您更好地理解。
linux sort 命令整理
无论是工作中使用还是应付各种面试,linux sort都是必须要掌握的 linux基本命令之一。尤其是 linux sort-k命令,经常会被搞晕,索性好好研究一下 sort命令
语法:
选项:
参数就不一一介绍了,直接上例子,首先先看下原始的排序数据
cat sort.log
1、打印从哪列开始是乱序
sort-c sort.log; echo$?
sort-C sort.log; echo$?
其中,返回结果 1,表示文件不是已经排序好的文件
2、默认排序(整行进行ASCII字符升序)
sort sort.log
3、高能来了,让人迷糊的 k语法,首先看下 k的语法格式
这个语法格式可以被其中的逗号(”,”)分为两大部分,Start部分和End部分
Start和End部分都由三部分组成,其中的Modifier部分就是类似n和r的选项部分,可省略
FStart、Fend,表示使用的域,而CStart则表示在FStart域中从第几个字符开始算"排序首字符",同理,CEnd表示结尾的第几个字符是排序末尾字符,.CStart、.CEnd是可以省略的,分别表示从本域的开头部分开始、到本域的域尾结束,CEnd设定为0,也是表示结尾到域尾。口说无凭,上几个例子吧
3.1对第三列进行排序,如果不加n,按照 ASCII字符排序
sort-t$'\t'-k 3 sort.log
3.2加n后,按照数值排序
sort-t$'\t'-k 3n sort.log
3.3不指定 FEnd时,多个-k从前往后排序可以,从后往前不行
从后往前,多个-k,数据符合预期
sort-t$'\t'-k 3n-k 1 sort.log
从后往前,多个-k,第三列相同时,按照第一列降序排列,数据符合预期
sort-t$'\t'-k 3n-k 1r sort.log
更换成从前往后
sort-t$'\t'-k 1-k 3n sort.log
sort-t$'\t'-k 1-k 3nr sort.log
通过 sort-t$'\t'-k 1-k 3n sort.log和 sort-t$'\t'-k 1-k 3nr sort.log返回的结果发现,在第一列相等时,无论其三列是正序排列,还是逆序排列,结果都一样,说明后边的-k未生效
当指定 FEend后
sort-t$'\t'-k 1,1-k 3nr sort.log
3.4作用域
紧跟在字段后的选项(如"-k3n"的"n"和"-k2nr"的"n","r")称为私有选项,使用短横线写在字段外的选项(如"-n"、"-r")为全局选项。当没有为字段分配私有选项时,该排序字段将继承全局选项,所有选项包括但不限于"bfnrhM"
除了"b"选项外,其余选项无论是指定在FStart还是FEnd中都是等价的,对于"b"选项,指定在FStart则作用于FStart,指定在FEnd则作用于FEnd
sort-t$'\t'-k1r,2 sort.log,可以看出一、二列都是倒叙排列
3.5注意
指定n选项按数值排序时,由于"n"选项只能识别数字和负号"-",当排序时遇到无法识别字符时,将导致该key的排序立即结束,n选项绝对不会跨域进行比较
默认情况下,sort会进行一次"最后的排序",按照默认规则对整行进行一次排序,这次排序称为"最后的排序"
sort-t$'\t'-k3n sort.log,在第三列相等时,整行会按照 ASCII进行最后的升序排列
sort-t$'\t'-k3,4n-s sort.log,加了-s后,不会进行最后的排序(1000相同时,e在b的前边了),而是保留原排序
3.6按照某个域中的第n个字符进行排序
sort-t$'\t'-k2.3,2.3 sort.log,按第二列第三个字符进行排序
4、-h使用易读性数字(例如:2K、1G)
sort-t$'\t'-k5h sort.log
sort-t$'\t'-k2,2 sort.log|uniq
sort-t$'\t'-k2,2-u sort.log会对第二列进行去重,而 sort-t$'\t'-k2,2 sort.log|uniq会对整行进行去重(当然uniq也可以按照第二列进行去重)
sort整理完了,欢迎大牛指教
linux命令sort
wps里面没有sortby函数?
有啊你没找到吗DP:?生活的脚步,技术的点滴...?sort命令用法?sort是在Linux里非常常用的一个命令,
linux查看文件句柄使用情况?
Linux查看文件句柄使用情况的方法:
1.查看当前系统的最大句柄数
ulimit-n
2.lsof命令查看有关文件句柄的详细信息,如当前系统打开的文件数量,哪些进程在使用这些文件句柄等等
查看进程PID打开的文件句柄详细信息:
lsof-ppid>
查看当前进程打开了多少句柄数:
lsof-n|awk{print$2}|sort|uniq-c|sort-nr|more
AIX和Linux下如何查看CPU和内存信息?
AIX的硬件信息可以通过prtconf命令看到。
1.查看逻辑CPU个数
#pmcycles-m
CPU0runsat4204MHz
CPU1runsat4204MHz
CPU2runsat4204MHz
CPU3runsat4204MHz
CPU4runsat4204MHz
CPU5runsat4204MHz
CPU6runsat4204MHz
CPU7runsat4204MHz
上面描述有8个CPU,CPU的主频为4.2G赫兹
2.查看物理CPU个数
#prtconf|grepProcessors
NumberOfProcessors:4
3.确定CPU是几核
用逻辑CPU除以物理CPU就是核数。
4.查看单个CPU的详细信息
#lsattr-E-lproc0
frequency4204000000ProcessorSpeedFalse
smt_enabledtrueProcessorSMTenabledFalse
smt_threads2ProcessorSMTthreadsFalse
stateenableProcessorstateFalse
typePowerPC_POWER6ProcessortypeFalse
Linux操作系统
Linux下的CPU信息全部都在/proc/cpuinfo这个文件中,可以直接打开看。
1.查看物理CPU的个数
#cat/proc/cpuinfo|grep"physicalid"|sort|uniq|wc-l
2.查看逻辑CPU的个数
#cat/proc/cpuinfo|grep"processor"|wc-l
3.查看CPU是几核
#cat/proc/cpuinfo|grep"cores"|uniq
4.查看CPU的主频
#cat/proc/cpuinfo|grepMHz|uniq
linux中的双竖线什么意思?
管道符号,是unix一个很强大的功能,符号为一条竖线:"|"。用法:command
1|command
2他的功能是把第一个命令command1执行的结果作为command2的输入传给command2,例如:$ls-s|sort-nr(请注意不要复制$符号进去哦)-s是filesize,-n是numeric-sort,-r是reverse,反转该命令列出当前目录中的文档(含size),并把输出送给sort命令作为输入,sort命令按数字递减的顺序把ls的输出排序。$ls-s|sort-n按从小到大的顺序输出。当然还可进行多次操作,如下面的功能为先去除纯数字,再由sed将竖线(这里不是管道符号)替换为空格,再将结果取出来排序,再进行结果的选择显示,不明白可查看排序和分页。catfilename|grep-v'^*$'|sed's/|//g'|sort-nrk8-nrk9|tail-n+1|head-n10
linuxgrep按顺序排列?
linuxgrep可按以下顺序排列:
1.sortfilename输出排序后的结果,默认按字符大小排序
2.-n按数字排序(如果内容是数字的话)
3.-M按月份排序(如果是三字符简写月份的话)
下面这个例子非常实用:
grep
1.grep$str$filename搜索文件里的特征串str,把命中的那行内容打印
2.-v打印没有命中的
3.-n打印的内容加上实际行号
4.-c只打印命中行数,不打印命中内容
5.-e指定多个匹配串
eg:grep-et-effile1打印命中't'或'f'的。
linux sort命令参数及用法详解
Linux sort命令用于将文本文件内容加以排序,sort可针对文本文件的内容,以行为单位来排序。
sort命令的语法格式:sort[参数][文件]
Linux sort命令参数:
-b:忽略每行前面开始出的空格符号。
-c:检查文件是否已经按照顺序排序。
-d:排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
-f:排序时,将小写字母视为大写字母。
-i:排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
-m:将几个排序好的文件进行合并。
-M:将前面三个字母依照月份的缩写进行排序。
-n:依照数值的大小排序。
-u:意味着是唯一的,输出的结果是去完重了的。
-o:<输出文件>将排序后的结果存入指定的文件。
-r:以相反的顺序来排序。
-t:<分隔字符>指定排序时所用的栏位分隔字符。
linux命令之排序命令sort命令
sort命令是对文件进行排序,并将排序的结果输出到屏幕,不影响原文件
以行为单位,将每一行作为一个单位,相互比较,比较原则是从首字符向后,以此按ASCII码进行比较,最后升序输出
参数
-b忽略每行前面开始处的空格
-d只按照英文字母,数字,空格字符排序,忽略其他字符
-m将几个排序好的文件进行合并
-n依照数值的大小进行排序,如果是按照数值大小排序一定要加-n,否则就会出现 10比2小的情况,因为默认比较数值是先比较第1位的,后面的位不考虑
-o将排序好的结果输出到文件,也可以使用重定向符号输出到文件中
-r以相反的顺序来排序,默认是升序
文章到此结束,如果本次分享的linuxsort和linux sort命令参数及用法详解的问题解决了您的问题,那么我们由衷的感到高兴!