-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpickle_btp.py
31 lines (22 loc) · 862 Bytes
/
pickle_btp.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
import pickle, sys, os, pysam
sample_list_path = '/data/allbam/190916_work/sample.btp5'
bam_dir = '/data/allbam'
slfile = open(sample_list_path, 'r')
sl_ls = slfile.readlines()
bam_list = []
slfile.close()
for sl_l in sl_ls :
bam_list.append(sl_l[:-1]+'.bwamem.sorted.dedup.realn.recal.dedup.bam')
for bamn, bam in enumerate(bam_list) :
print('\r', bam, ':', str(bamn)+'/'+str(len(bam_list)), ': start...', end='')
sys.stdout.write("\033[K")
sam_path = bam_dir+'/'+bam
if not os.path.isfile(sam_path) :
continue
print('\r', bam, ':', str(bamn)+'/'+str(len(bam_list)), ': opening bam file...', end='')
sf = open(sam_path, 'r')
print('\r', bam, ':', str(bamn)+'/'+str(len(bam_list)), ': loading bam file...', end='')
samfile = pysam.AlignmentFile(sf)
with open('pickle/'+bam+'.p', 'wb') as file:
pickle.dump(samfile, file)
samfile.close()