forked from bmajoros/python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBedReader.py
executable file
·76 lines (70 loc) · 2.75 KB
/
BedReader.py
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#=========================================================================
# This is OPEN SOURCE SOFTWARE governed by the Gnu General Public
# License (GPL) version 3, as described at www.opensource.org.
# Copyright (C)2016 William H. Majoros ([email protected]).
#=========================================================================
from __future__ import (absolute_import, division, print_function,
unicode_literals, generators, nested_scopes, with_statement)
from builtins import (bytes, dict, int, list, object, range, str, ascii,
chr, hex, input, next, oct, open, pow, round, super, filter, map, zip)
from Bed3Record import Bed3Record
from Bed6Record import Bed6Record
import re
#=========================================================================
# Attributes:
# fh : file handle
# Instance Methods:
# reader=BedReader(filename)
# record=reader.nextRecord() # Bed3Record or Bed6Record
# reader.close()
# list=BedReader.readAll(filename)
# hash=BedReader.hashBySubstrate(filename) # chr -> list of records
# Class Methods:
#
#=========================================================================
class BedReader:
"""BedReader reads bed3 and/or bed6 files"""
def __init__(self,filename):
self.fh=open(filename,"r")
@classmethod
def readAll(cls,filename):
reader=BedReader(filename)
array=[]
while(True):
record=reader.nextRecord()
if(not record): break
array.append(record)
reader.close()
return array
@classmethod
def hashBySubstrate(cls,filename):
list=cls.readAll(filename)
hash={}
for rec in list:
if(hash.get(rec.chr,None) is None):
hash[rec.chr]=[]
hash[rec.chr].append(rec)
return hash
def close(self):
self.fh.close()
def nextRecord(self):
while(True):
line=self.fh.readline()
if(not line): return None
if(not re.search("\S",line)): continue
line=line.rstrip()
line=line.lstrip()
fields=line.split()
n=len(fields)
if(n==3):
return Bed3Record(fields[0],int(fields[1]),int(fields[2]))
if(n==4):
return Bed6Record(fields[0],int(fields[1]),int(fields[2]),
fields[3],0.0,".")
if(n==5):
return Bed6Record(fields[0],int(fields[1]),int(fields[2]),
fields[3],float(fields[4]),".")
if(n==6):
return Bed6Record(fields[0],int(fields[1]),int(fields[2]),
fields[3],float(fields[4]),fields[5])
raise Exception("wrong number of fields in bed file: "+line)