Mercurial > repos > yating-l > hubarchivecreator
annotate cytoBand.py @ 57:b39dd0b5a166 draft
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit ce28781f52a4f84039de300cb41e3982f2e8bf51-dirty
author | yating-l |
---|---|
date | Fri, 30 Jun 2017 14:49:14 -0400 |
parents | ba9997c847dc |
children | 4c4e8941feda |
rev | line source |
---|---|
54
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
1 #!/usr/bin/python |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
2 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
3 import os |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
4 import tempfile |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
5 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
6 from Datatype import Datatype |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
7 from Track import Track |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
8 from TrackDb import TrackDb |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
9 from util import subtools |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
10 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
11 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
12 class cytoBand( Datatype ): |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
13 def __init__(self, input_bed_cytoBand_false_path, data_bed_cytoBand): |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
14 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
15 super(cytoBand, self).__init__() |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
16 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
17 self.input_bed_cytoBand_false_path = input_bed_cytoBand_false_path |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
18 self.name_bed_cytoBand = data_bed_cytoBand["name"] |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
19 self.priority = data_bed_cytoBand["order_index"] |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
20 self.track_color = data_bed_cytoBand["track_color"] |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
21 # TODO: Think about how to avoid repetition of the group_name everywhere |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
22 self.group_name = data_bed_cytoBand["group_name"] |
57
b39dd0b5a166
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit ce28781f52a4f84039de300cb41e3982f2e8bf51-dirty
yating-l
parents:
55
diff
changeset
|
23 self.database = data_bed_cytoBand["database"] |
54
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
24 if data_bed_cytoBand["long_label"]: |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
25 self.long_label = data_bed_cytoBand["long_label"] |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
26 else: |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
27 self.long_label = self.name_bed_cytoBand |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
28 sortedBedFile = tempfile.NamedTemporaryFile(suffix=".sortedBed") |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
29 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
30 # Sort processing |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
31 subtools.sort(self.input_bed_cytoBand_false_path, sortedBedFile.name) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
32 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
33 # bedToBigBed processing |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
34 # TODO: Change the name of the bb, to tool + genome + .bb |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
35 trackName = "".join( ( self.name_bed_cytoBand, '.bb' ) ) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
36 myBigBedFilePath = os.path.join(self.myTrackFolderPath, trackName) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
37 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
38 auto_sql_option = os.path.join(self.tool_directory, 'cytoBandIdeo.as') |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
39 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
40 with open(myBigBedFilePath, 'w') as bigBedFile: |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
41 subtools.bedToBigBed(sortedBedFile.name, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
42 self.chromSizesFile.name, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
43 bigBedFile.name, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
44 typeOption='bed4', |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
45 autoSql=auto_sql_option) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
46 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
47 # Create the Track Object |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
48 self.createTrack(file_path=trackName, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
49 track_name='cytoBandIdeo', |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
50 long_label=self.long_label, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
51 track_type='bigBed', |
55
ba9997c847dc
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit b2894a39921adaa6a93b12523820b61a78e11f20-dirty
yating-l
parents:
54
diff
changeset
|
52 visibility='dense', |
54
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
53 priority=self.priority, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
54 track_file=myBigBedFilePath, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
55 track_color=self.track_color, |
57
b39dd0b5a166
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit ce28781f52a4f84039de300cb41e3982f2e8bf51-dirty
yating-l
parents:
55
diff
changeset
|
56 group_name=self.group_name, |
b39dd0b5a166
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit ce28781f52a4f84039de300cb41e3982f2e8bf51-dirty
yating-l
parents:
55
diff
changeset
|
57 database=self.database) |
54
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
58 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
59 # dataURL = "tracks/%s" % trackName |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
60 # |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
61 # trackDb = TrackDb( |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
62 # trackName=trackName, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
63 # longLabel=self.name_bed_simple_repeats, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
64 # shortLabel=self.getShortName( self.name_bed_simple_repeats ), |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
65 # trackDataURL=dataURL, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
66 # trackType='bigBed 4 +', |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
67 # visibility='dense', |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
68 # priority=self.priority, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
69 # ) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
70 # |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
71 # self.track = Track( |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
72 # trackFile=myBigBedFilePath, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
73 # trackDb=trackDb, |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
74 # ) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
75 |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
76 print("- Bed splice junctions %s created" % self.name_bed_cytoBand) |
4a58094b051e
planemo upload for repository https://github.com/goeckslab/hub-archive-creator commit 754b3f960221a68b90f9cddd98a1c3dd324d4d4e-dirty
yating-l
parents:
diff
changeset
|
77 #print("- %s created in %s" % (trackName, myBigBedFilePath)) |