我想过滤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如下过滤UUID
$/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关键字后双引号内的内容进行分组,并用令牌替换整行.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。