-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathsam2fastq.py
executable file
·49 lines (35 loc) · 1.54 KB
/
sam2fastq.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
#! /bin/env python
# A custom script to obtain a fastq file from a sam file via CIGAR strings
# This is useful when there is a bam file with soft clipping
# that needs to be converted into a fastq file
# Soft clipped primers will be hard clipped in the output fastq.
import csv, sys, re
csv.field_size_limit(sys.maxsize) #JA 2022 OCT 11
if len(sys.argv) != 3:
raise Exception('Incorrect call to the script.')
samfilename = sys.argv[1]
fastqfilename = sys.argv[2]
with open(samfilename, 'r') as infile, open(fastqfilename, 'w') as outfile:
reader = csv.reader(infile, delimiter="\t", quoting=csv.QUOTE_NONE)
read_counter=1
for row in reader:
if row[0][0] != '@':
CIGAR = row[5]
seq = row[9]
quality = row[10]
# Process the CIGAR string
CIGAR_letters = [x for x in re.split('\d', CIGAR) if x]
CIGAR_numbers = [x for x in re.split('\D', CIGAR) if x]
if CIGAR_letters[0] == 'S':
start_pos = int(CIGAR_numbers[0])
else:
start_pos = 0
if CIGAR_letters[-1] == 'S':
end_pos = -int(CIGAR_numbers[-1])
else:
end_pos = len(seq)
trimmed_seq = seq[start_pos:end_pos]
trimmed_quality = quality[start_pos:end_pos]
# Output to the fastq file
outfile.writelines(["@read%d\n" % read_counter, trimmed_seq, "\n+\n", trimmed_quality, "\n"])
read_counter += 1