diff find_str.py @ 26:26e9575c2c83 draft

planemo upload for repository https://github.com/fubar2/microsatbed commit d952bc313f408735456747c3d33e09a3170c8f59-dirty
author fubar
date Fri, 19 Jul 2024 22:20:43 +0000
parents 8d0b8a75350f
children efc775ab30fe
line wrap: on
line diff
--- a/find_str.py	Fri Jul 19 06:41:18 2024 +0000
+++ b/find_str.py	Fri Jul 19 22:20:43 2024 +0000
@@ -1,5 +1,6 @@
 import argparse
 import shutil
+import subprocess
 
 import pybigtools
 import pytrf  # 1.3.0
@@ -19,9 +20,9 @@
         bin = int(b[1] / winwidth)
         d[bin] += nt
     dw = [
-        (name, (x * winwidth)+1, (x + 1) * winwidth, float(d[x]))
+        (name, (x * winwidth), ((x + 1) * winwidth) - 1, float(d[x]))
         for x in range(nwin + 1)
-        if  (x + 1) * winwidth <= chrlen - 1
+        if (x + 1) * winwidth <= chrlen
     ]
     return dw
 
@@ -78,14 +79,23 @@
                 cbed.append(row)
             elif args.hexa and len(ssr.motif) == 6:
                 cbed.append(row)
-        bed += cbed
         if args.bigwig:
             w = getDensity(name, cbed, chrlen, args.winwidth)
             wig += w
+        bed += cbed
     if args.bigwig:
         wig.sort()
-        bw = pybigtools.open("temp.bw", "w")
-        bw.write(chrlens, wig)
+        bedg = ['%s %d %d %.3f' % x for x in wig]
+        # bedg.insert(0,'track type=bedGraph') https://genomebrowser.wustl.edu/goldenPath/help/bigWig.html
+        with open("temp.bedg", "w") as bw:
+            bw.write('\n'.join(bedg))
+        chroms = ["%s\t%s" % (x, chrlens[x]) for x in chrlens.keys()]
+        with open("temp.chromlen", "w") as cl:
+            cl.write('\n'.join(chroms))
+        cmd = ["bedGraphToBigWig", "temp.bedg", "temp.chromlen", "temp.bw" ]
+        subprocess.run(cmd)
+        #bw = pybigtools.open("temp.bw", "w")
+        #bw.write(chrlens, wig)
         shutil.move("temp.bw", args.bed)
     else:
         bed.sort()