>我有一个属性文件,想逐行读取并将每一行拆分为一个数组。我在 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
。