CUS_PRODUCT_VER 这个变量前面为什么会多出一个换行符号
时间: 2023-08-12 10:05:13 浏览: 45
可能是因为在读取 CSV 文件时,每行结尾都有一个换行符,导致变量 csvSel 中保存的字符串也包含了一个换行符。在将 csvSel 中的 $CUS_PRODUCT_VER 后缀删除时,多出来的换行符也被删除了,因此在后续输出 CUS_PRODUCT_VER 的值时,会多出一个换行符。
为了避免这种情况,可以在使用 grep 查找时加上 -m 1 参数,仅返回第一个匹配的结果。同时,使用 echo 命令输出变量时,可以使用 -n 参数禁止输出结尾的换行符。例如:
```
csvSel=$(grep -m 1 "${CUS_PROJECT_NAME},${CUS_PRODUCT_ID},${CUS_OS_TYPE},${CUS_CUSTOMER_NAME}" "$myTargetFile")
delVercsv=${csvSel%$CUS_PRODUCT_VER}
echo -e "csv select:\n\t$csvSel"
echo -n "csv product version: $CUS_PRODUCT_VER"
CUS_PRODUCT_VER=$(echo "$CUS_PRODUCT_VER" | tr -cd "[0-9]" | awk '{printf "V%s.%s.%s.%s", substr($0,1,1), substr($0,2,1), substr($0,3,1), substr($0,4,1)}')
echo " 版本更新为: $CUS_PRODUCT_VER"
```
这样就可以避免变量中多出的换行符。
相关问题
CUS_PRODUCT_VER=`echo V${CUS_PRODUCT_VER:0:1}.${CUS_PRODUCT_VER:1:1}.${CUS_PRODUCT_VER:2:1}.${CUS_PRODUCT_VER:3:1}`清楚前后换行符号
可以使用以下代码来去除前后的空格和换行符:
```
CUS_PRODUCT_VER=$(echo V${CUS_PRODUCT_VER:0:1}.${CUS_PRODUCT_VER:1:1}.${CUS_PRODUCT_VER:2:1}.${CUS_PRODUCT_VER:3:1} | tr -d '[:space:]')
```
在这里,我们使用了 `tr` 命令来删除空格和换行符。其中 `[:space:]` 表示所有空白字符的字符类,包括空格、制表符、换行符等。这样可以确保变量中不含有多余的空格和换行符。
换一个方法 delVercsv=echo ${csvSel%$CUS_PRODUCT_VER}
这个命令不是一个完整的命令,缺少了 `$()` 语法。如果要将 `${csvSel%$CUS_PRODUCT_VER}` 的结果保存到 `$delVercsv` 变量中,应该使用下面的命令:
```
delVercsv=$(echo ${csvSel%$CUS_PRODUCT_VER})
```
这个命令首先执行了一个 `echo` 命令,将 `${csvSel%$CUS_PRODUCT_VER}` 的结果输出到标准输出,然后使用 `$()` 语法将输出结果保存到 `$delVercsv` 变量中。`${csvSel%$CUS_PRODUCT_VER}` 的含义是从变量 `$csvSel` 的末尾开始,删除最后一个匹配 `$CUS_PRODUCT_VER` 的字符串及其后面的内容,这里的 `$()` 语法可以让这个操作的结果被保存到一个变量中。