我正在开发一个bash脚本,该脚本将解析完整的字符串名称以提供固件值。例如,原始字符串名称将如下所示:
Example_v0p1
期望输出:
0.1
我的函数的第一部分根据下划线值消除字符串,并将数组的第二个元素设置为等于一个名为 version 的变量:
arr=(`echo $1| tr '_' ' '`)
version=${arr[1]}
使用我提供的示例,$version现在等于"v0p1"。我正在寻找一种进一步解析此字符串的方法,以便它看起来像所需的输出。
如果可能的话,我希望解决方案能够处理相同格式的多种变体,以便我可以对可以生成的所有版本代码使用相同的脚本。但是,语法将始终相同。v#p#{p#p#....}例子:
v0p1p1
v3p2p0p1
v1p3
期望输出:
0.1.1
3.2.0.1
1.3
我不确定解决此问题的最佳方法。我对 REGEX 没有足够的经验来完成这项工作,我无法想出一种适当的方法来解析字符串,因为它们将是不同的长度。
使用参数扩展:
#!/bin/bash
for v in v0p1p1 v3p2p0p1 v1p3 ; do
v=${v//[vp]/.} # Replace v's and p's with dots.
v=${v#.} # Remove the leading dot.
echo "$v"
done
你可以做这样的事情:
s='v3p2p0p1'
ver=$(sed 's/p/./g' <<< "${s:1}")
echo "$ver"
3.2.0.1
s='v0p1p1'
ver=$(sed 's/p/./g' <<< "${s:1}")
echo "$ver"
0.1.1
这将起作用:
var="$(echo "v0p1p1" | tr -s 'vp' " .")"
不过,它用空间代替了v
。
如果你不想这样做,你可以这样做:
var=$(echo "v0p1p1" | tr -d 'v' | tr -s 'p' '.')