Biopython - Création d'une application simple

Créons une application Biopython simple pour analyser un fichier bioinformatique et imprimer le contenu. Cela nous aidera à comprendre le concept général du Biopython et comment il aide dans le domaine de la bioinformatique.

Step 1 - Tout d'abord, créez un exemple de fichier de séquence, «example.fasta» et mettez-y le contenu ci-dessous.

>sp|P25730|FMS1_ECOLI CS1 fimbrial subunit A precursor (CS1 pilin) 
MKLKKTIGAMALATLFATMGASAVEKTISVTASVDPTVDLLQSDGSALPNSVALTYSPAV
NNFEAHTINTVVHTNDSDKGVVVKLSADPVLSNVLNPTLQIPVSVNFAGKPLSTTGITID 
SNDLNFASSGVNKVSSTQKLSIHADATRVTGGALTAGQYQGLVSIILTKSTTTTTTTKGT 

>sp|P15488|FMS3_ECOLI CS3 fimbrial subunit A precursor (CS3 pilin) 
MLKIKYLLIGLSLSAMSSYSLAAAGPTLTKELALNVLSPAALDATWAPQDNLTLSNTGVS 
NTLVGVLTLSNTSIDTVSIASTNVSDTSKNGTVTFAHETNNSASFATTISTDNANITLDK 
NAGNTIVKTTNGSQLPTNLPLKFITTEGNEHLVSGNYRANITITSTIKGGGTKKGTTDKK

L'extension, fasta fait référence au format de fichier du fichier de séquence. FASTA provient du logiciel de bioinformatique, FASTA, d'où son nom. Le format FASTA a plusieurs séquences organisées une par une et chaque séquence aura son propre identifiant, son nom, sa description et les données de séquence réelles.

Step 2 - Créez un nouveau script python, * simple_example.py "et entrez le code ci-dessous et enregistrez-le.

from Bio.SeqIO import parse 
from Bio.SeqRecord import SeqRecord 
from Bio.Seq import Seq 

file = open("example.fasta") 

records = parse(file, "fasta") for record in records:    
   print("Id: %s" % record.id) 
   print("Name: %s" % record.name) 
   print("Description: %s" % record.description) 
   print("Annotations: %s" % record.annotations) 
   print("Sequence Data: %s" % record.seq) 
   print("Sequence Alphabet: %s" % record.seq.alphabet)

Examinons un peu plus en détail le code -

Line 1importe la classe d'analyse disponible dans le module Bio.SeqIO. Le module Bio.SeqIO est utilisé pour lire et écrire le fichier de séquence dans un format différent et la classe `parse 'est utilisée pour analyser le contenu du fichier de séquence.

Line 2importe la classe SeqRecord disponible dans le module Bio.SeqRecord. Ce module est utilisé pour manipuler les enregistrements de séquence et la classe SeqRecord est utilisée pour représenter une séquence particulière disponible dans le fichier de séquence.

*Line 3"importe la classe Seq disponible dans le module Bio.Seq. Ce module est utilisé pour manipuler les données de séquence et la classe Seq est utilisée pour représenter les données de séquence d'un enregistrement de séquence particulier disponible dans le fichier de séquence.

Line 5 ouvre le fichier «example.fasta» en utilisant la fonction python ordinaire, ouvrez.

Line 7 analyse le contenu du fichier de séquence et renvoie le contenu sous forme de liste d'objets SeqRecord.

Line 9-15 boucle sur les enregistrements en utilisant python for loop et imprime les attributs de l'enregistrement de séquence (SqlRecord) tels que id, nom, description, données de séquence, etc.

Line 15 imprime le type de la séquence à l'aide de la classe Alphabet.

Step 3 - Ouvrez une invite de commande et allez dans le dossier contenant le fichier de séquence, "example.fasta" et exécutez la commande ci-dessous -

> python simple_example.py

Step 4- Python exécute le script et imprime toutes les données de séquence disponibles dans le fichier d'exemple, «example.fasta». La sortie sera similaire au contenu suivant.

Id: sp|P25730|FMS1_ECOLI 
Name: sp|P25730|FMS1_ECOLI 
Decription: sp|P25730|FMS1_ECOLI CS1 fimbrial subunit A precursor (CS1 pilin) 
Annotations: {} 
Sequence Data: MKLKKTIGAMALATLFATMGASAVEKTISVTASVDPTVDLLQSDGSALPNSVALTYSPAVNNFEAHTINTVVHTNDSD
KGVVVKLSADPVLSNVLNPTLQIPVSVNFAGKPLSTTGITIDSNDLNFASSGVNKVSSTQKLSIHADATRVTGGALTA
GQYQGLVSIILTKSTTTTTTTKGT 
Sequence Alphabet: SingleLetterAlphabet() 
Id: sp|P15488|FMS3_ECOLI 
Name: sp|P15488|FMS3_ECOLI 
Decription: sp|P15488|FMS3_ECOLI CS3 fimbrial subunit A precursor (CS3 pilin) 
Annotations: {} 
Sequence Data: MLKIKYLLIGLSLSAMSSYSLAAAGPTLTKELALNVLSPAALDATWAPQDNLTLSNTGVSNTLVGVLTLSNTSIDTVS
IASTNVSDTSKNGTVTFAHETNNSASFATTISTDNANITLDKNAGNTIVKTTNGSQLPTNLPLKFITTEGNEHLVSGN
YRANITITSTIKGGGTKKGTTDKK 
Sequence Alphabet: SingleLetterAlphabet()

Nous avons vu trois classes, parse, SeqRecord et Seq dans cet exemple. Ces trois classes fournissent la plupart des fonctionnalités et nous les apprendrons dans la section suivante.