linux - Bash 将 awk 的输出捕获到数组中

我遇到了一个小问题。我有一个将输出通过管道传输到 awk 的命令,但我想将输出一个一个地捕获到一个数组中。

我的例子:

myarr=$(ps -u kdride | awk '{ print $1 }')

但这会将我的所有输出捕获到一个用逗号分隔的巨大字符串中:

output: PID 3856 5339 6483 10448 15313 15314 15315 15316 22348 29589 29593 32657 1

我还尝试了以下方法:

IFS=","
myarr=$(ps -u kdride | awk '{ print $1"," }')

But the output is: PID, 3856, 5339, 6483, 10448, 15293, 15294, 15295, 15296, 22348, 29589, 29593, 32657,
1

我希望能够将每个单独的 pid 捕获到它自己的数组元素中。设置 IFS = '\n' 不会做任何事情并保留我的原始输出。我需要做哪些更改才能完成这项工作?

最佳答案

添加额外的括号,如下所示:

myarr=($(ps -u kdride | awk '{ print $1 }'))

# Now access elements of an array (change "1" to whatever you want)
echo ${myarr[1]}

# Or loop through every element in the array
for i in "${myarr[@]}"
do
   :
  echo $i
done

另见 bash — Arrays .

https://stackoverflow.com/questions/15105135/

相关文章:

c++ - 当父进程被杀死时,使用 fork() 创建的子进程是否会自动被杀死?

linux - Linux AMD64 中如何使用 fs/gs 寄存器?

linux - 通过 ssh 在远程服务器上执行命令

python - 在 Python 上模拟鼠标点击

linux - 在Linux中使用空格设置环境变量

c - 合并多个 .so 共享库

linux - Linux 的可视化补丁工具

linux - 使用 find 和 -exec {},有没有办法计算总数?

linux - 根据日期范围过滤日志文件条目

android - 如何构建在 Android 上运行的 native (命令行)可执行文件?