0

在 Linux 中,我有很多文件,我需要将所有文件的第 n 行的第 m 个单词连同文件名复制粘贴到一个普通的 .txt 文件中。所以我的最终文本文件看起来有点像这样......

<FileName1> <mth word of nth line of FileName1>
<FileName2> <mth word of nth line of FileName2>
.
.
<FileNameN> <mth word of nth line of FileNameN>

有人可以让我知道这个Linux命令。感谢您!!

4

2 回答 2

1
#!/bin/sh
if [ "$#" != 3 ]
then
  echo "$0 [dir] [lineno] [wordno]"
  exit
fi

rm -f a.txt
dir=$1
lineno=$2
wordno=$3

while read -u3 file
do
  read -a words < <(tail -n+$lineno $file)
  echo $file ${words[wordno-1]} >> a.txt
done 3< <(find $dir -type f)
于 2013-01-13T09:05:08.513 回答
0

怎么用awk

#!/bin/bash

# Usage: <line> <word> <files...>

awk "NR==$1 { print FILENAME \" \" \$$2 }" "${@:3}"
于 2013-01-13T09:59:25.603 回答