[Biopython] MultiProcess SeqIO objects

Willis, Jordan R jordan.r.willis at Vanderbilt.Edu
Mon Mar 5 22:37:30 EST 2012


Hello BioPython,

I was wondering if anyone has used the multiprocessing tool in conjunction with Biopython type objects? Here is my problem, I have 60 million sequences given in fastq format and I want to multiprocess these without having to iterate through the list multiple times.

So I have something like this:

from multiprocessing import Pool
from Bio import SeqIO

input_handle = open("huge_fastaqf_file.fastq,)


def convert_to_fasta(input)
	return [[record.id , record.seq.reverse_complement ] for record in SeqIO.parse(input,'fastq')]

p = Pool(processes=4)
g = p.map(convert_to_fasta,input_handle)

for i in g:
	print i[0],i[1]

Unfortunately, it  seems to divide up the handle by all the names and tries makes the input in the function convert_to_fasta the first line of input. What I want it to do is divide up the fastq object and do my function on 4 processors.

I can't figure out how in the world to do this though.

Thanks,
jordan 





More information about the Biopython mailing list