Blast output conversion in GFF requires a BLAST+ tabular format which can be
obtained by using the –outfmt 6 option with the default columns, as
mgkit.io.blast.parse_blast_tab(). The script can get data
from the standard in and ouputs GFF lines on the standard output by default.
mgkit.io.blast.parse_uniprot_blast() is used, which filters
BLAST hits based on bitscore and adds by default a db attribute to the
annotation with the value UNIPROT-SP, indicating that the SwissProt db is
used and a dbq attribute with the value 10. The feature type used in the GFF
If a BlastDB, such as nt or nr was used, the blastdb command offers some quick defaults to parse BLAST results.
It now includes options to control the way the sequence header are formatted. Options to change the separator used, as well as the column used as gene_id. This was added because at the moment the GI identifier (the second column in the header) is used, but it’s being phased out in favour of the embl/gb/dbj (right now the fourth column in the header). This should easy the transition to the new format and makes it easier to adapt an older pipeline/blastdb to newer files (like the ID to TAXA files).
The header from the a ncbi-nt header looks like this:
This is the default output accepted by the blastdb command. The fields are separated by | (pipe) and the GI is used (–gene-index 1, since internally the string is split by the separator and the second element is take - lists indices are 0-based in Python). This output uses the following options:
--header-sep '|' --gene-index 1
Notice the single quotes to pass the pipe symbol, since bash would interpret it as pipeing to the next coommand otherwise. This is the default.
In case, for the same header, we want to use the gb identifier, the only option to be specified is:
This will get the fourth element of the header (since we’re splitting by pipe).
As in the uniprot command, the gene_id can be set to use the whole header, using the -n option. Useful in case the BLAST db that was used was custom made. While pipe is used in major databases, it was made the default, by if the db used has different conventions the separator can be changed. There’s also the options of later changing the gene_id in the output GFF if necessary.
Changed in version 0.3.4: using click instead of argparse
Changed in version 0.2.6: added -r option to blastdb
Changed in version 0.2.5: added more options to give user control to the blastdb command
New in version 0.2.3: added –fasta-file option, added more data from a blsat hit
New in version 0.2.2: added blastdb command
Changed in version 0.2.1: added -ft option
Changed in version 0.1.13: added -n and -k parameters to uniprot command
New in version 0.1.12.
validate_params(ctx, param, values)¶