ps aux | grep tomcat| awk ‘{if(NR==1)print $2}‘
批量修改文件的分隔符,可以用FS和OFS命令
FS:Field Separator,字段分隔符
OFS:Out of Field Separator,输出字段分隔符
假设有这么一个文件file1.txt,其内容如下:
可以看出,file1的分隔符很长,不止一个空格符组成,因此我们需要先将分隔符统一一下,输入一下命令:
1
|
awk -F " " ‘{if($1~/^16/) print $1,$2,$3,$4}‘ file1.txt > file2.txt |
生成file2.txt,如下图片:
2. 修改分隔符为逗号
分隔符统一为一个空格,接下来将分隔符统一修改为逗号“,”,输入一下命令:
1
|
awk ‘BEGIN{ FS=" ";OFS="," }{ print $1,$2,$3,$4 }‘ file2.txt > file3.txt |
生成的文件file3.txt如下:
如果想将分隔符修改为冒号,只需要将OFS=","修改为OFS=":"
3.修改制表符为逗号
sampleID.txt文件如下:
005 018 105 100
首先判断文件是制表符还是空格:
1
|
sed -n l sampleID.txt ###判断文件时制表符还是空格分割的; |
如果是空格分割的,显示结果为:
005 018 105 100
如果是制表符分割,显示结果为:
005\t018\t105\t100
将制表符修改为逗号分隔符:
1
|
cat sampleID.txt| tr "\t" "," > sampleID_form.txt |
生成的sampleID_form.txt的内容如下:
005,018,105,100
1、打印文件的第一列(域) : awk ‘{print $1}‘ filename
2、打印文件的前两列(域) : awk ‘{print $1,$2}‘ filename
3、打印完第一列,然后打印第二列 : awk ‘{print $1 $2}‘ filename
4、打印文本文件的总行数 : awk ‘END{print NR}‘ filename
5、打印文本第一行 :awk ‘NR==1{print}‘ filename
6、打印文本第二行第一列 :sed -n "2, 1p" filename | awk ‘print $1‘
#(获取test文件的第4行)
#cat test| awk ‘NR==4‘或cat test|sed -n ‘4p‘直接获取某一行的数据
shell里面的赋值方法有两种,格式为
1) arg=`(命令)`
2) arg=$(命令)
因此,如果想要把某一文件的总行数赋值给变量nlines,可以表达为:
1) nlines=`(awk ‘END{print NR}‘ filename)`
或者
2) nlines=$(awk ‘END{print NR}‘ filename)
原文:https://www.cnblogs.com/But-you/p/10588233.html