Linux ksh(93u+) :逐行读取属性文件,并用 delim 拆分每一行



>我有一个属性文件,想逐行读取并将每一行拆分为一个数组。我在 Bash 中将 Split 字符串引用为数组,awk 语句看起来很复杂。同时,我想遵循链接中提供的建议。当我在 bash shell 中尝试命令时:

export $line1="table1;/users/user_name/dir1/dir2;/users/user_name/dirA/dirB" 
readarray -td; a <<<"$line1,"; unset 'a[-1]'; declare -p a;

引发错误。

bash: readarray: -d: invalid option
readarray: usage: readarray [-n count] [-O origin] [-s count] [-t] [-u fd] [-C callback] [-c quantum] [array]

不能在以下尴尬语句下:

array=()
while read -r -d $'' each; do   # use a NUL terminated field separator 
    array+=("$each")
done < <(printf "%s" "$str" | awk '{ gsub(/,[ ]+|$/,""); print }')
declare -p array

翻译成我的要求。

这是我阅读文件的方式:

while read record_line; do
    if [ ! -z "$record_line" -a "$record_line" != " " ]; then
    readarray -td; a <<<"$record_line,"; unset 'a[-1]'; declare -p a;
    fi
done<${PPROPERTIES_FILE} 

任何帮助。谢谢。

考虑以下事项

#!/usr/bin/env ksh
line=0
while IFS=';' read -rA pieces; do
  line=$(( line + 1 ))
  unset "pieces[0]"    # ignore first
  echo "Found pieces on line $line:"
  printf ' - %sn' "${all_pieces[@]}"
done <in.txt

请注意,与 bash 不同,读取 ksh 中的数组是用 -A 完成的,而不是-a

最新更新