免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6314 | 回复: 17
打印 上一主题 下一主题

新人求助,请各位大神帮帮忙!!!万分感谢! [复制链接]

论坛徽章:
1
狮子座
日期:2014-02-25 09:46:33
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-10-23 09:53 |只看该作者 |倒序浏览
本帖最后由 旋转小马 于 2013-10-23 11:12 编辑

生物信息中,这是一fastq文档,每四行是一个循环,现在我要看每个循环的第二行的碱基“A”或者“T”是否连续超过40个以上(包括40个),如果是的话,把这整个循环去掉,最后输出一个文件,用perl怎样实现?
@HWI-D00318:33:H166PADXX:2:1101:1337:2089 1:N:0:TAGCTT
AAAAACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
+
CCCFFADFHHHHHJJJJJJJHFDDDDDDDDDDDDDDDDDDBDBDDDDDDDDDBDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD
@HWI-D00318:33:H166PADXX:2:1101:1493:2146 1:N:0:TAGCTT
CAGATACACAGGAGTATTCAAAACCCTGGCAAGTATTGATGACAAACCGTCCCGTTTCGAAATTTTGATACCATTGGTACAAACTTTAGTTCGCGACAAT
+
CCCFFFFFHHHHHJGIJJJJJJJJJJJJJJJJJHIJJJJJJJJJJJJIIGIJJJJIJIJJJJHHHHHFFFFFFFEEEAEEDDDDDDDDDDDEDDDDDDDD
@HWI-D00318:33:H166PADXX:2:1101:1515:2150 1:N:0:TAGCTT
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
+
CCCFFFFFHHHHHJJJHFDDDDDDD8BDD@BDDDDDDDDDDDDDDDDDDDDDDDDDDDBDDDDDDDBDDDDDDDDBBDDDDBDDDDDDDDDDDDDDDDDD
@HWI-D00318:33:H166PADXX:2:1101:1798:2219 1:N:0:TAGCTT
CCTAAAGCCTAAGAGAGCAGGACTCAGGCTGGAGGCCTCTGCCTGGCCAGGATGAGGCTGAGGGCTTGGGGCAAAATTACTACCTGTCCTGATACCTGCA
+
CCCFFFFFHHHHHJJJJJJJJJJJJJJJJJJJJJJJJJJJJIJJJIJJJJJGIJJJJJJJIHHHDFFFDDDDDDDDDDDDDEDDDDDDDDDDDDDDDDDD
@HWI-D00318:33:H166PADXX:2:1101:2167:2087 1:N:0:TAGCTT
GCTGGGATGGGCCTCCAACTCCTCTGACAGGGCCTGCTAATCCAGCAGGAGCCTGGGGAATAGGTACACCTGCTGGCACTCCTCTGCCAGCTGCTCTTCC
+
CCCFFFFFHHHGHJJJJJJJJJIJJJJJJJIJJJJJJJJJJJJJJJJJJJGHJJIJJJJHHHHHBCFFFFEEEEEDDDDDDDDDDCDDDDDDDDDDDDDD
@HWI-D00318:33:H166PADXX:2:1101:2072:2182 1:N:0:TAGCTT
ATGCTGAGCTATCAGGTGTTCAGCCACAGTGGAGTTCTCCCCACTGCCTGTTGCTGTCATCCGGGCCACGTGGTCTACACCGATCCGTTCAGCTTCCTCA
+
CCCFFFFFHHHHHJJJGHIIJJJJJJJJJHIIHIJJJJJJJJJJJIJJJJIJJIJJHIJJJJJJJJHFFFCDDCEDDDDDDDDDDDDDDDDDDDDDDDDD
@HWI-D00318:33:H166PADXX:2:1101:2852:2107 1:N:0:TAGCTT
ATTTTTTTCTTTTTTTTTTTTTTTTACTGTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
+
@@@DDDDDHHHHHIIIIIIIIIE',((-(5>5<?B339BBBBBBBBBBBB5@BBBBBBBB7@BBBBBB8BB9@@BBBBBB>BB5@BBBBBBBBBBBBBBB
@HWI-D00318:33:H166PADXX:2:1101:4032:2050 1:N:0:TAGCTT
GATAATATCCGGGTAGGCGCAATCACTTTCGTCTACTCCGTTACAAAGCGAGGCTGGGTATTTCCCGGCCTTTCTGTTATCCGAAATCCACTGAAAGCAC
+
CCCFFFFFHHHHHBGHIJJJJJJJJIJJJJJJJJJJJJJJJJJJJJJIJJJJHFFFDDACDEEFEDDDDDDDDDDDEDDEDDDDDDDDDDDDDDDDDDDD

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
2 [报告]
发表于 2013-10-23 12:31 |只看该作者
  1. #!/usr/bin/perl -w

  2. my ( $in, $out ) = ( 'data.txt', 'save.txt' );
  3. open my $I, '<', $in  or die "$in\t$!";
  4. open my $S, '>', $out or die "$out\t$!";

  5. while (<$I>) {
  6.     my $line = <$I>;
  7.     if ( $line =~ /A{40,}/ or $line =~ /T{40,}/ ) { <$I>, <$I> }
  8.     else { print $S $_, $line, <$I> . <$I> }
  9. }

  10. print 'finish';
复制代码

论坛徽章:
1
狮子座
日期:2014-02-25 09:46:33
3 [报告]
发表于 2013-10-23 13:18 |只看该作者
结果不大对呢,就是在第二行中,若出现连续的“A”或“T”达到40或以上的时候,这一个循环去掉的,这里好像没实现!回复 2# pitonas


   

论坛徽章:
3
CU十二周年纪念徽章
日期:2013-10-24 15:41:34子鼠
日期:2013-12-14 14:57:19射手座
日期:2014-04-25 21:23:23
4 [报告]
发表于 2013-10-23 13:40 |只看该作者
期望的结果什么? LZ贴出来{:3_204:}

论坛徽章:
1
狮子座
日期:2014-02-25 09:46:33
5 [报告]
发表于 2013-10-23 13:54 |只看该作者
我这要是能得出结果就不求助大家了,上面的文档4行一循环,如果在每个循环中的第二行中,若“A”或“T”连续出现40次以上(包括40次),那么就把这一个循环去掉,最后输出剩下的文档就可以了!回复 4# mcshell


   

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
6 [报告]
发表于 2013-10-23 13:55 |只看该作者
这是实现, 8个循环 -> 5个循环 save.txt
  1. @HWI-D00318:33:H166PADXX:2:1101:1493:2146 1:N:0:TAGCTT
  2. CAGATACACAGGAGTATTCAAAACCCTGGCAAGTATTGATGACAAACCGTCCCGTTTCGAAATTTTGATACCATTGGTACAAACTTTAGTTCGCGACAAT
  3. +
  4. CCCFFFFFHHHHHJGIJJJJJJJJJJJJJJJJJHIJJJJJJJJJJJJIIGIJJJJIJIJJJJHHHHHFFFFFFFEEEAEEDDDDDDDDDDDEDDDDDDDD
  5. @HWI-D00318:33:H166PADXX:2:1101:1798:2219 1:N:0:TAGCTT
  6. CCTAAAGCCTAAGAGAGCAGGACTCAGGCTGGAGGCCTCTGCCTGGCCAGGATGAGGCTGAGGGCTTGGGGCAAAATTACTACCTGTCCTGATACCTGCA
  7. +
  8. CCCFFFFFHHHHHJJJJJJJJJJJJJJJJJJJJJJJJJJJJIJJJIJJJJJGIJJJJJJJIHHHDFFFDDDDDDDDDDDDDEDDDDDDDDDDDDDDDDDD
  9. @HWI-D00318:33:H166PADXX:2:1101:2167:2087 1:N:0:TAGCTT
  10. GCTGGGATGGGCCTCCAACTCCTCTGACAGGGCCTGCTAATCCAGCAGGAGCCTGGGGAATAGGTACACCTGCTGGCACTCCTCTGCCAGCTGCTCTTCC
  11. +
  12. CCCFFFFFHHHGHJJJJJJJJJIJJJJJJJIJJJJJJJJJJJJJJJJJJJGHJJIJJJJHHHHHBCFFFFEEEEEDDDDDDDDDDCDDDDDDDDDDDDDD
  13. @HWI-D00318:33:H166PADXX:2:1101:2072:2182 1:N:0:TAGCTT
  14. ATGCTGAGCTATCAGGTGTTCAGCCACAGTGGAGTTCTCCCCACTGCCTGTTGCTGTCATCCGGGCCACGTGGTCTACACCGATCCGTTCAGCTTCCTCA
  15. +
  16. CCCFFFFFHHHHHJJJGHIIJJJJJJJJJHIIHIJJJJJJJJJJJIJJJJIJJIJJHIJJJJJJJJHFFFCDDCEDDDDDDDDDDDDDDDDDDDDDDDDD
  17. @HWI-D00318:33:H166PADXX:2:1101:4032:2050 1:N:0:TAGCTT
  18. GATAATATCCGGGTAGGCGCAATCACTTTCGTCTACTCCGTTACAAAGCGAGGCTGGGTATTTCCCGGCCTTTCTGTTATCCGAAATCCACTGAAAGCAC
  19. +
  20. CCCFFFFFHHHHHBGHIJJJJJJJJIJJJJJJJJJJJJJJJJJJJJJIJJJJHFFFDDACDEEFEDDDDDDDDDDDEDDEDDDDDDDDDDDDDDDDDDDD
复制代码

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
7 [报告]
发表于 2013-10-23 13:57 |只看该作者
代码LZ贴出来

论坛徽章:
1
狮子座
日期:2014-02-25 09:46:33
8 [报告]
发表于 2013-10-23 14:02 |只看该作者
纳尼???我怎么没得到这结果!!!回复 6# pitonas


   

论坛徽章:
1
狮子座
日期:2014-02-25 09:46:33
9 [报告]
发表于 2013-10-23 14:13 |只看该作者
本帖最后由 旋转小马 于 2013-10-23 14:15 编辑

  1 #!/usr/bin/perl -w
  2 use strict;
  3 use PerlIO::gzip;
  4 open IN,"1Asel_L2_I010.R1.clean.fastq.gz"or die"Can not open IN.\n";
  5 open OUT,">R1.gz"or die"Can not open endfile.\n";  
  9 while (<IN>){
10         my $line = <IN>;
11         if($line =~/A{40}/ or $line =~/T{40}/){
12         <IN>;
13         <IN>;
14         }else{
15         print OUT $_, $line, <IN> . <IN> }
16 }
17         print 'finish';回复 7# pitonas


   

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
10 [报告]
发表于 2013-10-23 14:36 |只看该作者
please read doc how to use PerlIO::gzip
http://search.cpan.org/~nwclark/PerlIO-gzip-0.18/gzip.pm
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP