| 1 | #!/usr/bin/python2.6 |
|---|
| 2 | """ |
|---|
| 3 | For each interval in `bed1` count the number of intersecting regions in `bed2`. |
|---|
| 4 | |
|---|
| 5 | usage: %prog bed1 bed2 |
|---|
| 6 | """ |
|---|
| 7 | |
|---|
| 8 | import sys |
|---|
| 9 | from bx.intervals import * |
|---|
| 10 | |
|---|
| 11 | bed1,bed2 = sys.argv[1:3] |
|---|
| 12 | |
|---|
| 13 | ranges = {} |
|---|
| 14 | for line in open( bed2 ): |
|---|
| 15 | fields = line.strip().split() |
|---|
| 16 | chrom, start, end, = fields[0], int(fields[1]), int(fields[2]) |
|---|
| 17 | if chrom not in ranges: ranges[chrom] = Intersecter() |
|---|
| 18 | ranges[chrom].add_interval( Interval( start, end ) ) |
|---|
| 19 | |
|---|
| 20 | for line in open( bed1 ): |
|---|
| 21 | fields = line.strip().split() |
|---|
| 22 | chrom, start, end = fields[0], int(fields[1]), int(fields[2]) |
|---|
| 23 | other = " ".join(fields[3:]) |
|---|
| 24 | out = " ".join(fields[:3] +[other]) |
|---|
| 25 | if chrom in ranges: |
|---|
| 26 | print out, len( ranges[chrom].find( start, end ) ) |
|---|
| 27 | else: |
|---|
| 28 | print out, 0 |
|---|
| 29 | |
|---|