我有两个文件,table1.txt和table2.txt,第一列的字符为chr1,chr2,chr3。我想迭代一个命令,使它从两个表中只查询包含chr1,chr2,chr3中的一个的行,并将表的子集(称为所有行与chr1)传递给另一个命令(比如说cat,它接受两个表格作为输入)。输出然后保存为一个文件(比如new_chr1.txt用于chr1行上的操作)。使用for循环并将变量传递给命令
下面是这两个表的虚拟表示:
table1.txt:
chr1 5 55 1
chr1 14 62 1
chr1 47 97 1
chr2 4 52 1
chr2 20 70 1
chr2 25 75 1
chr3 3 52 1
chr3 6 56 1
chr3 10 60 1
table2.txt:
chr1 0 199
chr1 200 399
chr1 400 599
chr2 600 799
chr2 800 999
chr2 1000 1199
chr3 1200 1399
chr3 1400 1599
chr3 1600 1799
我尝试下面的代码:
for i in chr1 chr2 chr3
mkfifo table1
mkfifo table2
grep -w $i table1.txt > table1 &
grep -w $i table2.txt > table2 &
cat table1 table2 > new_$i.txt
done
以下是从我的屏幕拷贝,以显示我在每个阶段获得错误:
for i in chr1 chr2 chr3
mkfifo table1
-bash: syntax error near unexpected token `mkfifo'
mkfifo table2
grep -w $i table1.txt > table1 &
[5] 1969
grep -w $i table2.txt > table2 &
[6] 1970
cat table1 table2 > new_$i.txt
[5] Exit 1 grep -w $i table1.txt > table1
[6] Exit 1 grep -w $i table2.txt > table2
done
-bash: syntax error near unexpected token `done'
我无法找出什么地方出了错。如果我只运行上述命令而没有for
循环,并且没有mkfifo
,并且指定了要匹配的模式(比如chr1),它就可以正常工作。任何想法如何使这项工作?
顺便说一下,在我的实际代码中,我必须在两个grep
ed文件上运行另一个命令,而不是cat
。
喜乔纳森,THaks采摘这个错误在我的代码。 – user1938965
嗨乔纳森,你的意思是在grep命令之后加入等待吗? – user1938965
感谢您的帮助。 – user1938965