在 Bash 脚本中解析字符串变量



我正在开发一个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' '.')

相关内容

  • 没有找到相关文章

最新更新