免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: 56836430
打印 上一主题 下一主题

求助:关于核苷酸和氨基酸筛选的问题(已解决,感谢!) [复制链接]

论坛徽章:
1
操作系统版块每日发帖之星
日期:2015-10-08 06:20:00
11 [报告]
发表于 2016-03-30 10:06 |只看该作者
在这里真诚感谢各位的帮助,解决了我一个大问题!

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
12 [报告]
发表于 2016-03-30 16:24 |只看该作者
@hztj2005, @RE_HASH
佩服, 厉害啊... 向大神致敬!

论坛徽章:
0
13 [报告]
发表于 2016-03-30 18:39 |只看该作者
回复 12# sunzhiguolu

我多年用c++写代码,思路容易理顺。但对Perl并不熟悉,这段代码应该是很笨拙的,至少我自己是这样看。


   

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
14 [报告]
发表于 2016-03-30 18:57 |只看该作者
回复 13# hztj2005
大神谦虚了, 我感觉解决问题最重要的就是解决问题的思路.
至于使用什么语言, 都是工具, 次要的.

   

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
15 [报告]
发表于 2016-03-31 22:54 |只看该作者
回复 10# RE_HASH
nide code, very youyisi. ( nage gee wo kan le 1 tian ~ )
3Q ~ youyisi ~
perltidy ~
  1. #!/usr/bin/perl
  2. my ( $T, $R, $C );
  3. open C, "c.fasta";
  4. map { $T .= ( $_ > 5 ) ? "Y" : "N"; } <C>;
  5. close C;

  6. $T =~ s/(N+)/{ sprintf "(?:.{%d})", length $1 }/ge;
  7. $T =~ s/(Y+)/{ $C++; $R .= "\$C"; sprintf "(.{%d})", length $1 }/ge;

  8. sub CutFile {
  9.     my ( $F, $T, $R ) = @_;
  10.     open A, $F;
  11.     local $_ = do { $/ = undef; <A> };
  12.     close A;

  13.     s/(?<=\S{40})\n//g;
  14.     s/$T/qq(qq($R))/gee;
  15.     s/(\S{50})/$1\n/g;
  16.     return $_;
  17. }

  18. printf "d.fasta\n%s", CutFile( "a.fasta", $T, $R );
  19. print "\n\n";
  20. $T =~ s/(\d+)/{$1 * 3}/eg;
  21. printf "e.fasta\n%s", CutFile( "b.fasta", $T, $R );
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP