Пример #1
0
 def test_fasta_files(self):
     t = MQParam(TEMPLATE_PATH)
     t.add_fasta_files(('test1', 'test2'),
                       parse_rules={'identifierParseRule': r'>([^\s]*)'})
     assert len(t._root.find('fastaFiles')) == 2
     assert t._root.find('fastaFiles')[0].find("fastaFilePath").text == 'test1'
     assert t._root.find('fastaFiles')[0].find("identifierParseRule").text == '>([^\\s]*)'
Пример #2
0
from mqparam import MQParam

parser = argparse.ArgumentParser()

arguments = ('--infiles',
             '--version',
             '--num_threads',
             '--substitution_rx',
             '--fasta_files',
             '--description_parse_rule',
             '--identifier_parse_rule',
             'mqpar')

for arg in arguments:
    parser.add_argument(arg)

args = parser.parse_args()

mqpar_out = os.path.join(os.getcwd(), 'mqpar.xml')
infiles = [os.path.join(os.getcwd(), f) for f in args.infiles.split(',')]
mqparam = MQParam(args.mqpar, None, substitution_rx=args.substitution_rx)
if mqparam.version != args.version:
    raise Exception('mqpar version is ' + mqparam.version + '. Tool uses version {}.'.format(args.version))
mqparam.translate(infiles)
mqparam.add_fasta_files(args.fasta_files.split(','),
                        {'identifierParseRule': args.identifier_parse_rule,
                         'descriptionParseRule': args.description_parse_rule})
mqparam.set_simple_param('numThreads', args.num_threads)
mqparam.write('mqpar.xml')