1つのファイルの1行の内容を複数のファイルの別の行(同じ場所番号3)に置き換える必要があります。問題は次のとおりです。
1を入力してください
file.list <- list("a","b","c","d")
file.list <- list("d","e","f","g")
file.list <- list("h","i","l","m")
2.ファイル入力
library(data.table)
library(dplyr)
file.list <- list("z","g","h","s","i")
3.ファイル入力
library(data.table)
library(dplyr)
file.list <- list("s","p","q","r","m")
4.ファイル入力
library(data.table)
library(dplyr)
file.list <- list("x","k","s","e")
Input2.fileの出力
library(data.table)
library(dplyr)
file.list <- list("a","b","c","d")
Input3.fileの出力
library(data.table)
library(dplyr)
file.list <- list("d","e","f","g")
Input4.fileの出力
library(data.table)
library(dplyr)
file.list <- list("h","i","l","m")
私は以下を試してみます:
filename='Input1'
for i in *.file; do #here i loop over the list of files
while read p $filename; do #here i loop over the lines of Input1 file
awk '{ if (NR == 3) print "$p"; else print $0}' $i > $i.test; ##here i substitute the line 1 in the files with the line that are in Input1 file
done;
done
何のメッセージも表示せずにスクリプトが停止するため、何か間違ったことをしているのです。私は何が間違っていましたか?どんなアイデアがありますか?
ベストアンサー1
$ gawk -i inplace '
NR == FNR {repl[FNR] = $0; next}
FNR == 1 {filenum++}
FNR == 3 {$0 = repl[filenum]}
{print}
' Input1 Input{2,3,4}.file
$ cat Input2.file
library(data.table)
library(dplyr)
file.list <- list("a","b","c","d")
$ cat Input3.file
library(data.table)
library(dplyr)
file.list <- list("d","e","f","g")
$ cat Input4.file
library(data.table)
library(dplyr)
file.list <- list("h","i","l","m")
コードを確認してください。
- 各* .fileの3行をInput1の各行に置き換えます。各 *.file の 3 行目で、Input1 の最後の行が表示されます。
$p
一重引用符で囲まれているため、awkスクリプトでは拡張できません。
この試み:
exec 3<Input1 # set up file descriptor 3 to read from Input1 file
for f in *.file; do
read -r -u 3 replacement # read a line from fd 3
awk -v rep="$replacement" '{if (NR == 3) print rep; else print $0}' "$f" > "$f.test"
done
exec 3<&- # close fd 3