1、使用grep+sed+awk,查找编辑和输出。
例子:取得droped字段的值
原始输出
# show capture [0 pflow]: Interface:zc:1@1(12580) RX packets:29021 dropped:0 RX bit/sec:0.00(Mbps) pkt/sec:0.00(pps)
获取指定字段值
value=`show capture` echo "$value" | grep "dropped" | sed 's/:/ /g' | awk '{print $5}'
说明:使用grep找到字符串所在行,使用sed把冒号替换为空格,使用awk获取想要的字符串
2、使用sed正则表达式提取字符串
提取数字
[admin]# echo here365test666 | sed "s/.*ere\([0-9]*\)test\([0-9]*\)/\1\ \2/g" 365 666
s表示替换,\1和\2分别表示用第一个括号和第二个括号里面的内容,空格需要转义。sed支持*,不支持?、+,不能用d之类,正则支持有限。
整个sed表达式的作用是:用提取出的数字替换原来的字符串。
3、字符串变量截取
我们对以上 8 种格式做一个汇总,请看下表:
格式 | 说明 | 举例 |
---|---|---|
${string: start :length} | 从 string 字符串的左边第 start 个字符开始,向右截取 length 个字符。 |
[root]# var=HelloWorld |
${string: start} | 从 string 字符串的左边第 start 个字符开始截取,直到最后。 |
[root]# echo ${var:5} |
${string: 0-start :length} | 从 string 字符串的右边第 start 个字符开始,向右截取 length 个字符。 |
[root]# echo ${var:0-5:3} |
${string: 0-start} | 从 string 字符串的右边第 start 个字符开始截取,直到最后。 |
[root]# echo ${var:0-5} |
${string#*chars} | 从 string 字符串第一次出现 *chars 的位置开始,截取 *chars 右边的所有字符。 |
[root]# echo ${var#*l} |
${string##*chars} | 从 string 字符串最后一次出现 *chars 的位置开始,截取 *chars 右边的所有字符。 |
[root]# echo ${var##*l} |
${string%chars*} | 从 string 字符串第一次出现 chars* 的位置开始,截取 chars* 左边的所有字符。 |
[root]# echo ${var%l*} |
${string%%chars*} | 从 string 字符串最后一次出现 chars* 的位置开始,截取 chars* 左边的所有字符。 |
[root]# echo ${var%%l*} |