Bootstrap

shell 获取关键字后几位字符

文件: test.txt

"http-nio-8888-exec-3" #30 daemon prio=5 os_prio=0 tid=0x00007f9c10f39800 nid=0x687a waiting on condition [0x00007f9bde0ed000]
   java.lang.Thread.State: WAITING (parking)
	at sun.misc.Unsafe.park(Native Method)
	- parking to wait for  <0x00000000eca402c0> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
	at java.util.concurrent.locks.LockSupport.park(LockSupport.java:175)
	at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2039)
	at java.util.concurrent.LinkedBlockingQueue.take(LinkedBlockingQueue.java:442)
	at org.apache.tomcat.util.threads.TaskQueue.take(TaskQueue.java:108)
	at org.apache.tomcat.util.threads.TaskQueue.take(TaskQueue.java:33)
	at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:1074)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1134)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
	at java.lang.Thread.run(Thread.java:748)

   Locked ownable synchronizers:
	- None

比如我想获取关键字 concurrent 及后面 6 个字符,那么可以用以下命令:

# 这里的 16 是: concurrent 占用 10 个字符,外加后面的 6 个字符
cat test.txt | awk '{ if(match($0,"concurrent")) { print substr($0,RSTART,16) }}'

获取效果如下:

root@dreamboy:~/test# cat test.txt | awk '{ if(match($0,"concurrent")) { print substr($0,RSTART,16) }}'
concurrent.locks
concurrent.locks
concurrent.locks
concurrent.Linke
concurrent.Threa
concurrent.Threa
concurrent.Threa
root@dreamboy:~/test# 

如果不想要 concurrent 关键字,可以使用:

cat test.txt | awk '{ if(match($0,"concurrent")) { print substr($0,RSTART+RLENGTH,6) }}'

补充资料 - awk 内置变量

属 性说 明
$0当前记录行,代表一行记录
1   1~ 1 n当前记录的第n个字段,字段间由FS分隔
FS输入字段分隔符,默认是空格
NF当前记录中的字段个数,就是有多少列,一般取最后一列字段
NR已经读出的记录数,就是行号,从1开始
RS输入的记录分隔符,默认为换行符
OFS输出字段分隔符,默是空格
ORS输出的记录分隔符,默认为换行符
ARGC命令行参数个数
ARGV命令行参数数组
FILENAME当前输入文件的名字
IGNORECASE如果为真,则进行忽略大小写的匹配
ARGIND当前被处理文件的ARGV标志符
CONVFMT数字转换格式 %.6g
ENVIRONUNIX环境变量
ERRNOUNIX系统错误消息
FIELDWIDTHS输入字段宽度的空白分隔字符串
FNR当前记录数
OFMT数字的输出格式 %.6g
RSTART被匹配函数匹配的字符串首
RLENGTH被匹配函数匹配的字符串长度
SUBSEP\034
;