如何解决将命令输出分成单独的变量
我正在尝试在macos时间机器上使用bash脚本。
我正在尝试读取时间机器备份目标的属性,然后在有多个目标的情况下将目标拆分为变量。
从那里我可以使用ID进行备份。
我无法将输出分成自己的变量。
rawdstinfo=$(tmutil destinationinfo)
echo "$rawdstinfo"
> ==================================================
Name : USB HDD
Kind : Local
Mount Point : /Volumes/USB HDD
ID : 317BD93D-7D90-494C-9D5F-9013B25D1345
====================================================
Name : TM TEST
Kind : Local
Mount Point : /Volumes/TM TEST
ID : 4648083B-2A11-42BC-A8E0-D95917053D27
我当时想计算==================================================
,然后尝试根据它们拆分变量,但是我没有运气。
任何帮助将不胜感激。
谢谢
PS: 为了明确说明我要实现的目标,我想将每个目标驱动器发送给一个对象。从那里,我可以比较安装点名称(在脚本的前面已选择),然后获取该对象内的“目标ID”,因此可以将其与其他tmutil命令(如
)一起使用#start a TM backup
sudo tmutil startbackup --destination $DESTINATIONID
#remove Migration HDD as a destination
sudo tmutil removedestination $DESTINATIONID
解决方法
我喜欢使用awk解析定界的平面文件。我从问题中复制了tmutil输出,并将其粘贴到名为testdata.txt的文件中,因为我在Mac上没有这样做。确保记录分隔符中的等号数目实际上与tmutil产生的内容匹配。
这是解决方案的awk部分,它进入了一个名为timemachine_variables.awk的文件:
function ltrim(s) { sub(/^[ \t\r\n]+/,"",s); return s }
function rtrim(s) { sub(/[ \t\r\n]+$/,s); return s }
function trim(s) { return rtrim(ltrim(s)); }
BEGIN {
RS="====================================================\n";
FS=":|\n"
}
{
i=FNR-1
}
(FNR>1 && $1 ~ /Name/) {print "Name["i"]="trim($2)}
(FNR>1 && $3 ~ /Kind/) {print "Kind["i"]="trim($4)}
(FNR>1 && $5 ~ /Mount Point/) {print "Mount_Point["i"]="trim($6)}
(FNR>1 && $7 ~ /ID/) {print "ID["i"]="trim($8)}
开始时的功能是修剪任何字段的前导或尾随空白。我根据等号分隔符拆分记录,并根据冒号“:”字符拆分字段。 FNR是gawk的内部变量,用于我们正在查看的当前记录号。由于输出显然以等号开头,因此第一条记录为空,因此我将FNR> 1作为排除它的条件。然后我有gawk打印代码,它将成为bash的数组分配。在您的示例中,这应该是gawk的输出:
$ gawk -f timemachine_variables.awk testdata.txt
Name[1]=USB HDD
Kind[1]=Local
Mount_Point[1]=/Volumes/USB HDD
ID[1]=317BD93D-7D90-494C-9D5F-9013B25D1345
Name[2]=TM TEST
Kind[2]=Local
Mount_Point[2]=/Volumes/TM TEST
ID[2]=4648083B-2A11-42BC-A8E0-D95917053D27
在您的BASH脚本中,从gawk脚本的输出中声明数组:
$ declare $(gawk -f timemachine_variables.awk testdata.txt)
现在每个驱动器都应具有BASH阵列:
$ echo ${ID[2]}
4648083B-2A11-42BC-A8E0-D95917053D27
更新:我发布的原始awk脚本在Mac上不起作用,因为BSD awk不支持多字符分隔符。我将其保留在此处,因为它适用于gawk,比较两个脚本可能会帮助正在寻找一种方法来实现BSD awk中多字符分隔符行为的其他人。
我没有更改默认记录分隔符(即行尾),而是将自己的i计数器设置为0,然后在每次整个记录开始并以一个或多个等号结束时将其递增。由于awk现在将每一行视为自己的记录,并且字段分隔符仍为“:”,因此我们要匹配的名称始终为$ 1,值始终为$ 2。
function ltrim(s) { sub(/^[ \t\r\n]+/,s); return s }
function trim(s) { return rtrim(ltrim(s)); }
BEGIN {
FS=":";
i=0;
}
($0 ~ /^=+$/) {i++;}
($1 ~ /Name/) {print "Name["i"]="trim($2)}
($1 ~ /Kind/) {print "Kind["i"]="trim($2)}
($1 ~ /Mount Point/) {print "Mount_Point["i"]="trim($2)}
($1 ~ /ID/) {print "ID["i"]="trim($2)}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。