用perl計算序列中各種核苷酸頻數(shù)

計算序列中各種核苷酸頻數(shù)

#!/usr/bin/perl -w
# Determining frequency of nucleotides

# Get the name of the file with the DNA sequence data
print "Please type the filename of the DNA sequence data: ";

$dna_filename = <STDIN>;

# Remove the newline from the DNA filename
chomp $dna_filename;

# open the file, or exit
unless ( open(DNAFILE, $dna_filename) ) {

    print "Cannot open file \"$dna_filename\"\n\n";
    exit;
}

# Read the DNA sequence data from the file, and store it
# into the array variable @DNA
@DNA = <DNAFILE>;

# Close the file
close DNAFILE;

# From the lines of the DNA file,
# put the DNA sequence data into a single string.
$DNA = join( '', @DNA);

# Remove whitespace
$DNA =~ s/\s//g;

# Now explode the DNA into an array where each letter of the
# original string is now an element in the array.
# This will make it easy to look at each position.
# Notice that we're reusing the variable @DNA for this purpose.
@DNA = split( '', $DNA );

# Initialize the counts.
# Notice that we can use scalar variables to hold numbers.
$count_of_A = 0;
$count_of_C = 0;
$count_of_G = 0;
$count_of_T = 0;
$errors     = 0;

# In a loop, look at each base in turn, determine which of the
# four types of nucleotides it is, and increment the
# appropriate count.
foreach $base (@DNA) {

    if      ( $base eq 'A' ) {
        ++$count_of_A;
    } elsif ( $base eq 'C' ) {
        ++$count_of_C;
    } elsif ( $base eq 'G' ) {
        ++$count_of_G;
    } elsif ( $base eq 'T' ) {
        ++$count_of_T;
    } else {
        print "!!!!!!!! Error - I don\'t recognize this base: $base\n";
        ++$errors;
    }
}

# print the results
print "A = $count_of_A\n";
print "C = $count_of_C\n";
print "G = $count_of_G\n";
print "T = $count_of_T\n";
print "errors = $errors\n";

# exit the program
exit;

small.dna進行展示

Please type the filename of the DNA sequence data: small.dna
!!!!!!!! Error - I don't recognize this base: V
A = 40
C = 27
G = 24
T = 17
errors = 1

small.dna

AAAAAAAAAAAAAAGGGGGGGTTTTCCCCCCCC
CCCCCGTCGTAGTAAAGTATGCAGTAGCVG
CCCCCCCCCCGGGGGGGGAAAAAAAAAAAAAAATTTTTTAT
AAACG

split函數(shù)將序列分割成單個字符串(與join函數(shù)功能相反)升熊。

關(guān)于foreach循環(huán),每進行一次级野,$bash就會取@DNA的下一個值粹胯。

注意蓖柔,對變量進行自加的方法有多種风纠,例如

++$count;
$count++;
$count = $count + 1;
$count += 1;

注意前兩種寫法還是有一些區(qū)別的(基本每種編程語言都會涉及),一般情況可以通用镐捧。

腳本中的foreach循環(huán)也可以改成以下形式:

foreach (@DNA){
  if ( /A/ ) {
     ++$count_of_A;
  }
  .......其余類似
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末臭增,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子速址,更是在濱河造成了極大的恐慌,老刑警劉巖芍锚,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異默刚,居然都是意外死亡,警方通過查閱死者的電腦和手機荤西,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門伍俘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人癌瘾,你說我怎么就攤上這事》镣耍” “怎么了蜕企?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵冠句,是天一觀的道長。 經(jīng)常有香客問我懦底,道長,這世上最難降的妖魔是什么奋构? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任拱层,我火速辦了婚禮弥臼,結(jié)果婚禮上根灯,老公的妹妹穿的比我還像新娘。我一直安慰自己烙肺,他們只是感情好,可當我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布氏堤。 她就那樣靜靜地躺著搏明,像睡著了一般鼠锈。 火紅的嫁衣襯著肌膚如雪星著。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天同欠,我揣著相機與錄音,去河邊找鬼铺遂。 笑死,一個胖子當著我的面吹牛娃循,可吹牛的內(nèi)容都是我干的斗蒋。 我是一名探鬼主播捌斧,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼泉沾,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了跷究?” 一聲冷哼從身側(cè)響起姓迅,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤俊马,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后柴我,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡聋伦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年界睁,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片翻斟。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖敞斋,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情植捎,我是刑警寧澤,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布焰枢,位于F島的核電站舌剂,受9級特大地震影響济锄,放射性物質(zhì)發(fā)生泄漏霍转。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一低滩、第九天 我趴在偏房一處隱蔽的房頂上張望召夹。 院中可真熱鬧恕沫,春花似錦、人聲如沸婶溯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至叙身,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間曲梗,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工愧旦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人笤虫。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓祖凫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親惠况。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容