免费注册 查看新帖 |

Chinaunix

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

生物信息学中“最好”开放阅读框提取脚本分析 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-04-11 10:43 |只看该作者 |倒序浏览
本帖最后由 小时间抓紧我 于 2014-04-11 10:44 编辑


从中挑出一条“最好”的ORF,即sus1和sus2中只要一条,以下脚本怎么解释,求详解~~
#!/usr/bin/perl
use strict;
use warnings;
use Getopt::Long;

#set parameter
my $version=1.00;
my %opts;
GetOptions(\%opts,"r=s","w=s","h");
if (!(defined $opts{w} && defined $opts{r}) || defined $opts{h})
{
        &usage;
}
open Input,"$opts{r}";   #fas_l.list
open Output,">$opts{w}.c.fas";
open Check,">check";
my $sp="";
my $seq="";
my $len=0;
my $check=0;
while (<Input>){
        s/\n|\r//g;
  if(/>(\w+)_\d+ \[(\d+) - (\d+)\]/) {
          print Check "$1\t$2\t$3\t";
          if (($1 ne $sp) and ($sp ne "")){
                  print Output ">$sp\n$seq\n";
                  $seq="";
                  $check=1;
                  $len=$3-$2;
          }
          else {
                  if (($3-$2)>$len) {
                          $check=1;
                          $seq="";
                        $len=$3-$2;
                  }
                  else {$check=0;}                 
          }
          $sp=$1;
          print Check "$len";
  }
  else {
          if ($check==1){$seq.=$_;}
  }
}
print Output ">$sp\n$seq\n";
close Input;
close Output;

论坛徽章:
8
技术图书徽章
日期:2013-09-30 08:51:28技术图书徽章
日期:2013-12-11 09:26:39白羊座
日期:2013-12-27 15:27:13金牛座
日期:2014-01-06 09:13:05天蝎座
日期:2014-01-21 14:23:28酉鸡
日期:2014-05-09 16:51:12卯兔
日期:2014-08-11 16:49:1515-16赛季CBA联赛之八一
日期:2017-08-14 23:24:57
2 [报告]
发表于 2014-04-11 11:00 |只看该作者
所谓的最好的 其实就是最长的

论坛徽章:
0
3 [报告]
发表于 2014-04-11 11:02 |只看该作者
我也检查过,这个脚本提出来的不一定是最长的,所以觉得很奇怪,想问一下这个脚本到底是什么意思回复 2# xiumu2280


   

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
4 [报告]
发表于 2014-04-11 14:15 |只看该作者
到处都是默认变量和默认写法。人肉编译器的感觉真是不好。
明明是 WINDOWS 系统,每个代码前都要加上 #!/usr/bin/perl

论坛徽章:
0
5 [报告]
发表于 2014-04-14 10:48 |只看该作者
求脚本解释:wink: 回复 4# 104359176


   

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
6 [报告]
发表于 2014-04-14 10:57 |只看该作者
回复 5# 小时间抓紧我


    无能为力,专业术语太多,代码又长,又烂。不忍直视。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
7 [报告]
发表于 2014-04-14 11:40 |只看该作者
回复 5# 小时间抓紧我


    直接贴上来一大段代码,也不说什么地方看不懂,你这也太偷懒了吧?要是所有地方都看不懂,那你还是找本 Perl 入门书先看看吧。

论坛徽章:
0
8 [报告]
发表于 2014-04-14 12:12 |只看该作者
就是if语句后边那部分语句是什么意思回复 7# MMMIX


   

论坛徽章:
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
9 [报告]
发表于 2014-04-14 12:35 |只看该作者
你说的很对, 感觉真是不好。

104359176 发表于 2014-04-11 07:15

明明是 WINDOWS 系统,每个代码前都要加上
#!/usr/bin/perl
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP