# HG changeset patch # User drosofff # Date 1452878970 18000 # Node ID 60b6bd959929cf1a14fcd5cbac8f15ee6b7b1709 # Parent 8f5d48294f70d76a54acb92f5e02a36921659d38 planemo upload for repository https://github.com/ARTbio/tools-artbio/tree/master/tools/msp_blastparser_and_hits commit e842488e979d8a00b9646061573355cb427bc89c diff -r 8f5d48294f70 -r 60b6bd959929 BlastParser_and_hits.py --- a/BlastParser_and_hits.py Mon Oct 19 12:13:12 2015 -0400 +++ b/BlastParser_and_hits.py Fri Jan 15 12:29:30 2016 -0500 @@ -1,5 +1,5 @@ #!/usr/bin/python -# blastn blastx parser revised debugged: 3-4-2015. Commit issue. +# blastn tblastn blastx parser revised 14-1-2016. # drosofff@gmail.com import sys @@ -17,6 +17,8 @@ the_parser.add_argument('--filter_relativeCov', action="store", type=float, default=0, help="filter out relative coverages below the specified ratio (float number)") the_parser.add_argument('--filter_maxScore', action="store", type=float, default=0, help="filter out best BitScores below the specified float number") the_parser.add_argument('--filter_meanScore', action="store", type=float, default=0, help="filter out mean BitScores below the specified float number") + the_parser.add_argument('--filter_term_in', action="store", type=str, default="", help="select the specified term in the subject list") + the_parser.add_argument('--filter_term_out', action="store", type=str, default="", help="exclude the specified term from the subject list") the_parser.add_argument('--al_sequences', action="store", type=str, help="sequences that have been blast aligned") the_parser.add_argument('--un_sequences', action="store", type=str, help="sequences that have not been blast aligned") args = the_parser.parse_args() @@ -127,21 +129,40 @@ leftCoordinate = 1 return getseq (fastadict, FastaHeader, leftCoordinate, rightCoordinate, polarity) -def outputParsing (F, Fasta, results, Xblastdict, fastadict, filter_relativeCov=0, filter_maxScore=0, filter_meanScore=0, mode="verbose"): +def outputParsing (F, Fasta, results, Xblastdict, fastadict, filter_relativeCov=0, filter_maxScore=0, filter_meanScore=0, filter_term_in="", filter_term_out="", mode="verbose"): + def filter_results (results, filter_relativeCov=0, filter_maxScore=0, filter_meanScore=0, filter_term_in="", filter_term_out=""): + print "###", filter_term_in + for subject in results.keys(): + if results[subject]["RelativeSubjectCoverage"]>F, "# SeqId\t%Identity\tAlignLength\tStartSubject\tEndSubject\t%QueryHitCov\tE-value\tBitScore\n" for subject in sorted (results, key=lambda x: results[x]["meanBitScores"], reverse=True): - if results[subject]["RelativeSubjectCoverage"]> F, "#\n# %s" % subject print >> F, "# Suject Length: %s" % (results[subject]["subjectLength"]) print >> F, "# Total Subject Coverage: %s" % (results[subject]["TotalCoverage"]) @@ -163,8 +184,6 @@ else: print >>F, "# subject\tsubject length\tTotal Subject Coverage\tRelative Subject Coverage\tBest Bit Score\tMean Bit Score" for subject in sorted (results, key=lambda x: results[x]["meanBitScores"], reverse=True): - if results[subject]["RelativeSubjectCoverage"] + for virus discovery @@ -14,6 +14,8 @@ --filter_relativeCov $additional_filters.filter_relativeCov --filter_maxScore $additional_filters.filter_maxScore --filter_meanScore $additional_filters.filter_meanScore + --filter_term_in "$additional_filters.filter_term_in" + --filter_term_out "$additional_filters.filter_term_out" #end if --al_sequences $al_sequences --un_sequences $un_sequences @@ -38,6 +40,8 @@ + +