linuxsort(Linux技巧)
一、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都是必须要掌握的 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命令参数及用法详解
功能说明:将文本文件内容加以排序。
语法:sort [-bcdfimMnr][-o输出文件][-t分隔字符][+起始栏位-结束栏位][--help][--verison][文件]
补充说明:sort可针对文本文件的内容,以行为单位来排序。
参数:
-b 忽略每行前面开始出的空格字符。
-c 检查文件是否已经按照顺序排序。
-d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
-f 排序时,将小写字母视为大写字母。
-i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
-m 将几个排序好的文件进行合并。
-M 将前面3个字母依照月份的缩写进行排序。
-n 依照数值的大小排序。
-o输出文件 将排序后的结果存入指定的文件。
-r 以相反的顺序来排序。
-t分隔字符 指定排序时所用的栏位分隔字符。
+起始栏位-结束栏位 以指定的栏位来排序,范围由起始栏位到结束栏位的前一栏位。
--help 显示帮助。
--version 显示版本信息
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
下面通过几个例子来讲述Sort的使用。
用Sort命令对text文件中各行排序后输出其结果。请注意,在原文件的第二、三行上的第一个单词完全相同,该命令将从它们的第二个单词vegetables与fruit的首字符处继续进行比较。
$ cat text
vegetable soup
fresh vegetables
fresh fruit
lowfat milk
$ Sort text
fresh fruit
fresh vegetables
lowfat milk
vegetable soup
用户可以保存排序后的文件内容,或把排序后的文件内容输出至打印机。下例中用户把排序后的文件内容保存到名为result的文件中。
$ Sort textresult
以第2个字段作为排序关键字对文件example的内容进行排序。
$ Sort+1-2 example
对于file1和file2文件内容反向排序,结果放在outfile中,利用第2个字段的第一个字符作为排序关键字。
$ Sort-r-o outfile+1.0-1.1 example
Sort排序常用于在管道中与其他命令连用,组合完成比较复杂的功能,如利用管道将当前工作目录中的文件送给Sort进行排序,排序关键字是第6个至第8个字段。
$ ls- l| Sort+5- 7
$ ps-e-o" comm pid time"|Sort-d//按照command的首字母的字母顺序排序
Sort命令也可以对标准输入进行操作。例如,如果您想把几个文件文本行合并,并对合并后的文本行进行排序,您可以首先用命令cat把多个文件合并,然后用管道操作把合并后的文本行输入给命令Sort,Sort命令将输出这些合并及排序后的文本行。在下面的例子中,文件veglist与文件 fruitlist的文本行经过合并与排序后被保存到文件clist中。
$ cat veglist fruitlist| Sort clist