awk命令提取某行的最后一个数值
发布网友
发布时间:2022-04-25 12:24
我来回答
共3个回答
热心网友
时间:2024-09-06 20:20
TS=`grep "energy" OUTCAR | tail -1 | awk '{printf "%12.8f \n", $8 }'`
echo $TS >>comment
这样就可以了。
反引号`内的命令被赋值给变量TS。echo $TS输出变量,用>>将输出重定向到comment文件中。
反引号内的命令一共是3个,通过2次管道将输出进行传递。
grep "energy" OUTCAR表示搜索OUTCAR文件中带有energy单词的行
| 表示将上一个命令的输出结果作为下一个命令的输入
tail -1表示取最后一行,这个根据你的OUTCAR文件的内容而定,如果只有一行有单词energy,就不需要这个命令,如果有多行包含energy,就根据需要取相应行。
awk '{printf "%12.8f \n", $8 }' 表示将行的第8列打印出来,awk命令默认列分隔符就是空格,所以你这一行所需要取的数值在第8列上。打印格式为精确到小数点后8位(数值总位数为12位),根据你需要的精度取舍。如果要取完整的数值,也可以直接将这部分改为awk '{printf, $8 }'。
就是这样了。
热心网友
时间:2024-09-06 20:21
你可以直接用awk这样做:
awk 'BEGIN{FS="="}{print $2}' xxx.txt
因为我看你最后一个字段前有一个等号,所以用FS="="作为指定字段分隔符
热心网友
时间:2024-09-06 20:21
假设文件是OUTCAR
TS=`grep "energy" OUTCAR |tail -1 |awk '{print $5}'`
echo $TS >> comment