sed – 用于从blkid程序的输出中过滤UUID的工具(使用grep,cut或awk,e.t.c)

前端之家收集整理的这篇文章主要介绍了sed – 用于从blkid程序的输出中过滤UUID的工具(使用grep,cut或awk,e.t.c)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想过滤blkid的输出获取UUID.

blkid的输出看起来像

情况1:-

$blkid
/dev/sda2: LABEL="A" UUID="4CC9-0015"
/dev/sda3: LABEL="B" UUID="70CF-169F"
/dev/sda1: LABEL=" NTFS_partition" UUID="3830C24D30C21234"

在某些情况下,blkid的输出看起来像

案例2: –

$blkid
/dev/sda1: UUID="d7ec380e-2521-4fe5-bd8e-b7c02ce41601" TYPE="ext4" 
/dev/sda2: UUID="fc54f19a-8ec7-418b-8eca-fbc1af34e57f" TYPE="ext4" 
/dev/sda3: UUID="6f218da5-3ba3-4647-a44d-a7be19a64e7a" TYPE="swap"

我想过滤掉UUID.

使用grep和cut的组合可以完成

/sbin/blkid | /bin/grep 'sda1' | /bin/grep -o -E 'UUID="[a-zA-Z|0-9|\-]*' | /bin/cut -c 7-

我已经尝试使用awk,grep和cut如下过滤U​​UID

$/sbin/blkid | /bin/grep 'sda1' | /usr/bin/awk '{print $2}' | /bin/sed 's/\"//g' | cut -c 7-
7ec380e-2521-4fe5-bd8e-b7c02ce41601

上述命令(使用awk)是不可靠的,因为有时在blkid程序的输出中可能存在诸如LABEL的额外字段,如上面的输出所示.

使用可靠工作的awk创建命令的最佳方法是什么?
如果任何其他优雅的方法使用bin和core utils退出作业,请发布.我不想使用perl或python,因为这必须在busyBox上运行.

注意: – 我正在使用busyBox blkid,其中/ dev / sda1不能作为args传递(我正在使用的版本不支持它)因此grep过滤该行.

更新: – 添加了CASE 2:-output以显示无法依赖字段位置.

解决方法

对于所有UUID,您可以:
$blkid | sed -n 's/.*UUID=\"\([^\"]*\)\".*/\1/p' 
d7ec380e-2521-4fe5-bd8e-b7c02ce41601
fc54f19a-8ec7-418b-8eca-fbc1af34e57f
6f218da5-3ba3-4647-a44d-a7be19a64e7a

比方说,只针对特定的sda1:

$blkid | sed -n '/sda1/s/.*UUID=\"\([^\"]*\)\".*/\1/p' 
d7ec380e-2521-4fe5-bd8e-b7c02ce41601

sed命令尝试对UUID关键字后双引号内的内容进行分组,并用令牌替换整行.

原文链接:https://www.f2er.com/linux/394980.html

猜你在找的Linux相关文章