如何查找文件中的第n个单词(Linux Shell)



我正在尝试编写一个Shell脚本,该脚本采用文件名和数字,并打印出文件中的第n个单词。有什么简单的命令可以做到这一点吗?

尝试:

#!/bin/bash
tr 'n' ' ' < "$1" | cut -d' ' -f$2

然后运行:

./script.sh filename.txt 30

假设:单词由单个空格分隔,单词不包含空格。

如果你想处理标点符号和多个空格,试试之类的东西

#!/bin/bash
sed -e 's/[[:punct:]]*//g;s/[[:space:]]+/n/g' < $1 | sed $2q;d

你可以试试这个

#!/bin/bash
awk -v var=$2 '{print $var}' < $1

运行示例:

./script.sh filename.txt 30

相关内容

  • 没有找到相关文章

最新更新