如何使用参数扩展从bash中的字符串中删除空行?

问题描述

我有以下变量。

echo "|${VAR1}|"

哪个返回

|
ABC

XYZ|

如何删除空行、保留换行符和使用参数扩展?这样它就会变成

|ABC
XYZ|

ps:我知道如何使用管道 sed 来做到这一点,但我想避免额外的 SED 过程:

VAR1=`echo "${VAR1}" | sed '/^\s*$/d'`

解决方法

删除前导换行符,然后用一个换行符替换任何连续的换行符。

#! /bin/bash

var='
ABC

XYZ'

expected='ABC
XYZ'

shopt -s extglob
var=${var##+($'\n')}
var=${var//+($'\n')/$'\n'}
[[ $var == $expected ]] && echo OK
,

将变量的行读入数组,并删除空元素

var1=$'\nABC\n\nXYZ'
mapfile -t arr <<<"$var1"

declare -p arr                  # => declare -a arr=([0]="" [1]="ABC" [2]="" [3]="XYZ")

for ((i = ${#arr[@]} - 1; i >= 0; i--)); do
    [[ -z ${arr[i]} ]] && unset "arr[i]"
done

declare -p arr                  # => declare -a arr=([1]="ABC" [3]="XYZ")

(IFS=$'\n'; echo "|${arr[*]}|")  # in a subshell for temporary IFS setting
|ABC
XYZ|

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...