亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 3703 | 回復(fù): 12
打印 上一主題 下一主題

求一個更高效的程序,內(nèi)附自己小白程序! [復(fù)制鏈接]

論壇徽章:
3
2015亞冠之武里南聯(lián)
日期:2015-07-29 12:14:352015年亞冠紀(jì)念徽章
日期:2015-08-12 14:28:272015亞冠之德黑蘭石油
日期:2015-09-09 17:15:52
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2015-07-29 17:22 |只看該作者 |倒序瀏覽
while (<IN>) {
chomp;
my $line=$_;
my @snp_data=split/\t/,$line;
my $chr="chr"."$snp_data[0]";
     foreach  (@gene) {
     chomp;
         my @pos= split /\t/,$_;
         
     next if $pos[0] ne $chr ;
         
         if(($snp_data[1]>=$pos[2])&&($snp_data[1]<=$pos[3])){
                 print OUT "$line\n";next;
                 }
   
}


}

我是期待的分隔線…………………………………………

這個程序的意思就是:gene 和 In的第一列的數(shù)字部分相同,并且 In 的第二列在gene 的三四列范圍之間,就輸出IN;
數(shù)據(jù)量大,兩個循環(huán)很費時間。
<@gene>
chr1        ABCA4        94458582        94586799
chr1        ACADM        76190031        76229363
chr16        BBS2        56518258        56554008
chr17        G6PC        41052813        41066450
chr17        GAA        78078244        78093271

。。。。。。2000行


<IN>
1        94505603        rs368951547        C        T        NA        NA
1        94505604        rs61750126        A        C        0.02066        NA
1        94505611        rs137853898        G        A        NA        not-provided
1        94505620        rs370967816        T        A        NA        NA
1        94505621        rs149503495        T        C        NA        NA
1        94505627        rs374610040        A        G        NA        NA
22        18901263        rs377148163        C        A        NA        NA
22        18901290        rs381848        G        A        0.07989        NA
22        18901322        rs62232347        C        A        NA        NA
22        18901326        rs201353896        TCC        T        0.05005        NA
22        18901327        rs10537001        CCT        C        0.0528        NA
16        18901326        rs201353896        TCC        T        0.05005        NA
17        18901327        rs10537001        CCT        C        0.0528        NA
。。。。。。很多很多萬行




論壇徽章:
95
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
2 [報告]
發(fā)表于 2015-07-29 17:43 |只看該作者
回復(fù) 1# 54red


    把 gene 放到 hash 中。

論壇徽章:
7
戌狗
日期:2013-12-15 20:43:38技術(shù)圖書徽章
日期:2014-03-05 01:33:12技術(shù)圖書徽章
日期: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聯(lián)賽之青島
日期:2016-03-17 20:36:13
3 [報告]
發(fā)表于 2015-07-30 00:40 |只看該作者
shishi:
  1. #!/usr/bin/perl
  2. open my $G, 'gene';
  3. open my $I, 'IN';

  4. my %gene;

  5. while (<$G>) {
  6.     my ( $chr, undef, $r1, $r2 ) = split;
  7.     ($chr) = $chr =~ /(\d+)/;
  8.     push @{ $gene{$chr} }, [ $r1, $r2 ];
  9. }

  10. for ( values %gene ) {
  11.     @$_ = sort { $a->[0] <=> $b->[0] } @$_;
  12. }

  13. while (<$I>) {
  14.     my ( $chr, $pos ) = split /\s+/, $_, 3;
  15.     next unless exists $gene{$chr};
  16.     for my $R ( @{ $gene{$chr} } ) {
  17.         last if $pos < $R->[0];
  18.         next if $pos > $R->[1];
  19.         print;
  20.         last;
  21.     }
  22. }
復(fù)制代碼

評分

參與人數(shù) 1信譽(yù)積分 +20 收起 理由
54red + 20 學(xué)到很多!十分感謝!

查看全部評分

論壇徽章:
7
戌狗
日期:2013-12-15 20:43:38技術(shù)圖書徽章
日期:2014-03-05 01:33:12技術(shù)圖書徽章
日期: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聯(lián)賽之青島
日期:2016-03-17 20:36:13
4 [報告]
發(fā)表于 2015-07-30 01:02 |只看該作者
回復(fù) 1# 54red
  1. foreach (@gene) {
  2.     chomp;
  3.     my @pos= split /\t/, $_;
復(fù)制代碼
biru IN you 10 wan hang
gene 1 hang
chomp 10 wan ci
split 10 wan ci

論壇徽章:
3
2015亞冠之武里南聯(lián)
日期:2015-07-29 12:14:352015年亞冠紀(jì)念徽章
日期:2015-08-12 14:28:272015亞冠之德黑蘭石油
日期:2015-09-09 17:15:52
5 [報告]
發(fā)表于 2015-07-31 14:34 |只看該作者
用了樓上的程序,現(xiàn)在基本可以在半個小時出結(jié)果了,速度提高了100倍左右,再次感謝!

論壇徽章:
95
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
6 [報告]
發(fā)表于 2015-07-31 14:51 |只看該作者
回復(fù) 5# 54red


    其實,要數(shù)據(jù)量真的比較大(G級),而且你需要對其進(jìn)行各種搜索,就上數(shù)據(jù)庫吧。

論壇徽章:
7
戌狗
日期:2013-12-15 20:43:38技術(shù)圖書徽章
日期:2014-03-05 01:33:12技術(shù)圖書徽章
日期: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聯(lián)賽之青島
日期:2016-03-17 20:36:13
7 [報告]
發(fā)表于 2015-08-01 05:16 |只看該作者
回復(fù) 6# MMMIX

半個小時出結(jié)果

Do you have any medicines for this?
@104359176
@jason680

論壇徽章:
7
戌狗
日期:2013-12-15 20:43:38技術(shù)圖書徽章
日期:2014-03-05 01:33:12技術(shù)圖書徽章
日期: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聯(lián)賽之青島
日期:2016-03-17 20:36:13
8 [報告]
發(fā)表于 2015-08-01 06:26 |只看該作者
回復(fù) 5# 54red

keyi upload your data? (gene: all, IN: 1/2 or 1/4 or all)
wo shishi xie 1 ge bijiaokuaide code,
(dan bushi perl)
   

求職 : 軟件工程師
論壇徽章:
3
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-07 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-12-13 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2016-05-05 06:20:00
9 [報告]
發(fā)表于 2015-08-01 12:11 |只看該作者
這個涉及到對另外一個大型的數(shù)據(jù)結(jié)構(gòu)進(jìn)行查詢,這種算法半小時算快的了。

論壇徽章:
95
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
10 [報告]
發(fā)表于 2015-08-01 13:52 |只看該作者
本帖最后由 MMMIX 于 2015-08-01 13:59 編輯

回復(fù) 7# rubyish


    導(dǎo)入數(shù)據(jù)庫,建好索引,然后再查詢。G級的數(shù)據(jù),估計幾分鐘也就出來了。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP