0
|
1 #!/usr/bin/perl -w
|
|
2 # Author: Thomas Thiel
|
|
3 # Program name: prim_output.pl
|
|
4 # Description: converts the Primer3 output into an table
|
|
5
|
|
6 open (SRC,"<$ARGV[0]") || die ("\nError: Couldn't open Primer3 results file (*.p3out) !\n\n");
|
|
7 my $filename = $ARGV[0];
|
|
8 $filename =~ s/\.p3out//;
|
|
9 open (IN,"<$ARGV[1]") || die ("\nError: Couldn't open source file containing MISA (*.misa) results !\n\n");
|
|
10 open (OUT,">$ARGV[2]") || die ("nError: Couldn't create file !\n\n");
|
|
11
|
|
12 my ($seq_names_failed,$count_failed,$count);
|
|
13 print OUT "ID\tSSR nr.\tSSR type\tSSR\tsize\tstart\tend\t";
|
|
14 print OUT "FORWARD PRIMER1 (5'-3')\tTm(°C)\tsize\tREVERSE PRIMER1 (5'-3')\tTm(°C)\tsize\tPRODUCT1 size (bp)\tstart (bp)\tend (bp)\t";
|
|
15 print OUT "FORWARD PRIMER2 (5'-3')\tTm(°C)\tsize\tREVERSE PRIMER2 (5'-3')\tTm(°C)\tsize\tPRODUCT2 size (bp)\tstart (bp)\tend (bp)\t";
|
|
16 print OUT "FORWARD PRIMER3 (5'-3')\tTm(°C)\tsize\tREVERSE PRIMER3 (5'-3')\tTm(°C)\tsize\tPRODUCT3 size (bp)\tstart (bp)\tend (bp)\n";
|
|
17
|
|
18 undef $/;
|
|
19 my $in = <IN>;
|
|
20 study $in;
|
|
21
|
|
22 $/ = "=\n";
|
|
23
|
|
24 while (<SRC>)
|
|
25 {
|
|
26 my ($id,$ssr_nr) = (/PRIMER_SEQUENCE_ID=(\S+)_(\d+)/);
|
|
27
|
|
28 $in =~ /($id\t$ssr_nr\t.*)\n/;
|
|
29 my $misa = $1;
|
|
30
|
|
31 /PRIMER_LEFT_SEQUENCE=(.*)/ || do {$count_failed++;print OUT "$misa\n"; next};
|
|
32 my $info = "$1\t";
|
|
33
|
|
34 /PRIMER_LEFT_TM=(.*)/; $info .= "$1\t";
|
|
35 /PRIMER_LEFT=\d+,(\d+)/; $info .= "$1\t";
|
|
36
|
|
37 /PRIMER_RIGHT_SEQUENCE=(.*)/; $info .= "$1\t";
|
|
38 /PRIMER_RIGHT_TM=(.*)/; $info .= "$1\t";
|
|
39 /PRIMER_RIGHT=\d+,(\d+)/; $info .= "$1\t";
|
|
40
|
|
41 /PRIMER_PRODUCT_SIZE=(.*)/; $info .= "$1\t";
|
|
42 /PRIMER_LEFT=(\d+),\d+/; $info .= "$1\t";
|
|
43 /PRIMER_RIGHT=(\d+),\d+/; $info .= "$1\t";
|
|
44
|
|
45
|
|
46 /PRIMER_LEFT_1_SEQUENCE=(.*)/; $info .= "$1\t";
|
|
47 /PRIMER_LEFT_1_TM=(.*)/; $info .= "$1\t";
|
|
48 /PRIMER_LEFT_1=\d+,(\d+)/; $info .= "$1\t";
|
|
49
|
|
50 /PRIMER_RIGHT_1_SEQUENCE=(.*)/; $info .= "$1\t";
|
|
51 /PRIMER_RIGHT_1_TM=(.*)/; $info .= "$1\t";
|
|
52 /PRIMER_RIGHT_1=\d+,(\d+)/; $info .= "$1\t";
|
|
53
|
|
54 /PRIMER_PRODUCT_SIZE_1=(.*)/; $info .= "$1\t";
|
|
55 /PRIMER_LEFT_1=(\d+),\d+/; $info .= "$1\t";
|
|
56 /PRIMER_RIGHT_1=(\d+),\d+/; $info .= "$1\t";
|
|
57
|
|
58
|
|
59 /PRIMER_LEFT_2_SEQUENCE=(.*)/; $info .= "$1\t";
|
|
60 /PRIMER_LEFT_2_TM=(.*)/; $info .= "$1\t";
|
|
61 /PRIMER_LEFT_2=\d+,(\d+)/; $info .= "$1\t";
|
|
62
|
|
63 /PRIMER_RIGHT_2_SEQUENCE=(.*)/; $info .= "$1\t";
|
|
64 /PRIMER_RIGHT_2_TM=(.*)/; $info .= "$1\t";
|
|
65 /PRIMER_RIGHT_2=\d+,(\d+)/; $info .= "$1\t";
|
|
66
|
|
67 /PRIMER_PRODUCT_SIZE_2=(.*)/; $info .= "$1\t";
|
|
68 /PRIMER_LEFT_2=(\d+),\d+/; $info .= "$1\t";
|
|
69 /PRIMER_RIGHT_2=(\d+),\d+/; $info .= "$1";
|
|
70
|
|
71 $count++;
|
|
72 print OUT "$misa\t$info\n"
|
|
73 };
|
|
74
|
|
75 #print "\nPrimer modelling was successful for $count sequences.\n";
|
|
76 #print "Primer modelling failed for $count_failed sequences.\n";
|