-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsga_to_tss.pl
36 lines (30 loc) · 1.14 KB
/
sga_to_tss.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#!/usr/bin/perl
# script to convert EPD SGA TSS files to TSS format
# Source files location ftp://ccg.epfl.ch/epdnew/, e.g. ftp://ccg.epfl.ch/epdnew/H_sapiens/current/Hs_EPDnew.sga
# (C) Yuri Kravatsky, lokapal@gmail.com
use strict;
my $ARGC=scalar @ARGV;
if ($ARGC==0||$ARGC>1) { die "Usage: sgr_to_txt TSSfile.sga\n"; }
my $infile=$ARGV[0];
my $basename=substr($infile,0,rindex($infile,"."));
my $outfile=$basename.".txt";
open (EP,$infile) || die "Can't open \"$infile\" for reading: $!";
open (OUTP,">$outfile") || die "Can't create \"$outfile\": $!";
while (<EP>) {
chomp;
chomp;
if (length($_)<5) { next; }
if ($_=~ m/^(\s+)?#/) { print OUTP "$_\n"; next; } # commented strings written in the same order
my @arr=split(/\t/);
my $name=$arr[0];
$name=~ s/NC_0000/chr/g;
$name=~s/chr0/chr/g;
$name=~s/\.\d+//g;
$name=~s/chr23/chrX/g;
$name=~s/chr24/chrY/g;
my $gene=$arr[5];
$gene =~ s/_(\d+)$//;
print OUTP "$name\t$arr[2]\t$arr[3]\t$gene\n";
}
close (EP);
close (OUTP);