IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bioinformatique Perl Discussion :

problème de Boucle infinie


Sujet :

Bioinformatique Perl

  1. #1
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 4
    Points : 3
    Points
    3
    Par défaut problème de Boucle infinie
    Bonjour tous le monde,

    Je débute en perl, et je crois avoir un problème de boucle infinie. Voila j'ai un répertoire dans lequel se trouve des fiches EMBL. Je dois parcourir chaque fiche de mon répertoire pour y extraire le numéro d'accession de mes séquences ainsi que les séquences et le écrire dans un autre fichier.
    J'ai donc fais cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
     
    #!/usr/bin/perl
     
    use warnings;
    use strict;
     
    my $sequence="";
    my $seq; 
    my $id;
    my $ficheEMBL="ID+fiche";
    my $nomFichier="ID+fiche";
    my $line="";
     
    # ouvre le répertoire contenant toutes les fiches EMBL.txt
    opendir(DIR,$ficheEMBL) || die "Impossible d'ouvrir le fichier";
    open(OUT, ">totalNumAc+Seq.txt") || die "Impossible d'ouvrir le fichier";
     
    while($nomFichier = readdir(DIR))
    {
     
    	# ouvre chaque fichier comprit dans le repertoire
    	open(FILE,$ficheEMBL."/".$nomFichier)||die "Impossible d'ouvrir le fichier";
     
    	#regarde s'il y a des fichiers cachés "." ou/et ".." si oui passe les fichiers sans les traiter
    	if($nomFichier eq "." or $nomFichier eq "..")
    	{
    		# permet de passer le fichier
    		next;
    	}
     
    	while ($line = <FILE>) 
    	{
     
    		if ($line =~ m/^AC\s+(\S+);/m) 
    		{ 
    		        my $id = $1 ; 
    			print OUT ">$id, ";
     
    		}
     
    		elsif ($line =~ m/^DE\s+([^\n]+)/mg) 
    		{
    			my $title = $1;
    		        print OUT" $title ";
    		}
     
    		# quand on arrive à la séquence on met $seq à 1
    		# afin de récupérer les lignes suivantes
     
    		elsif ($line =~ m/^SQ/)
    		{
    			$seq = 1;
    		}
     
    		# si $seq est à 1, cela signifie que nous sommes dans la séquence
    		# donc on récupère la ligne dans la variable $sequence
     
    		elsif ( ($seq) && ($line =~ /([\sa-z]+)\d+/))
    		{
    			$sequence.= $1; 
    			$sequence =~ tr/acgt/ACGT/;
     
    		}
     
    	} 
    	# suppression des espaces 
    	$sequence =~ s/\s//g;	 
    	print OUT "\n$sequence.";
    	close (FILE) || die "Impossible de fermer le fichier";
    	exit(0);
    }
     
    close (OUT)  || die "imposible de fermer le fichier"; 
    # ferme le répertoire
    closedir (DIR)  || die "Impossible de fermer le répertoire";
    Je n'arrive pas à trouver mon erreur, alors si vous avez des conseilles pour moi je suis preneuse

  2. #2
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Points : 12 469
    Points
    12 469
    Billets dans le blog
    1
    Par défaut
    Ton répertoire s'appelle "ID+fiche"? Bizarre comme nom de répertoire. Surtout que ton code semple impliquer que le nom de fichier est aussi "ID+fiche". A mon avis, il y a une erreur dès cet endroit;

  3. #3
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Oui je sais les noms ne sont pas très explicite, mais ça ne pose pas de problème dans mon programme. (enfin je crois)
    J'ai trouvé une erreur, j'oubliais de remettre $sequence et $seq à 0 ou vide. Mais quand je lance mon programme même si il m'affiche se que je souhaite dans mon fichier il ne me rend pas la main sur le terminal et ne traite pas toutes les fiches de mon répertoire.
    Pouvez vous m'aider

  4. #4
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Voici, mon programme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    #!/usr/bin/perl
     
    use warnings;
    use strict;
     
     
     
    my $sequence="";
    my $seq; 
    my $id;
    my $ficheEMBL="ID+fiche";
    my $nomFichier="ID+fiche";
    my $line="";
     
    # ouvre le répertoire contenant toutes les fiches EMBL.txt
    opendir(DIR,$ficheEMBL) || die "Impossible d'ouvrir le fichier";
    open(OUT, ">totalNumAc+Seq.txt") || die "Impossible d'ouvrir le fichier";
     
    while($nomFichier = readdir(DIR))
    {
     
    	# ouvre chaque fichier comprit dans le repertoire
    	open(FILE,$ficheEMBL."/".$nomFichier)||die "Impossible d'ouvrir le fichier";
    	$sequence =""; 
    	$seq=0;
    	#regarde s'il y a des fichiers cachés "." ou/et ".." si oui passe les fichiers sans les traiter
    	if($nomFichier eq "." or $nomFichier eq "..")
    	{
    		# permet de passer le fichier
    		next;
    	}
     
    	while ($line = <FILE>) 
    	{
     
    	 	#print "coucou\n";
    		if ($line =~ m/^AC\s+(\S+);/m) 
    		{ 
    		    my $id = $1 ; 
    			print OUT ">$id, ";
     
    		}
     
    		elsif ($line =~ m/^DE\s+([^\n]+)/mg) 
    		{
    			my $title = $1;
    		    print OUT" $title ";
    		}
     
    		# quand on arrive à la séquence on met $seq à 1
    		# afin de récupérer les lignes suivantes
    		elsif ($line =~ m/^SQ/)
    		{
    			$seq = 1;
    		}
     
    		# si $seq est à 1, cela signifie que nous sommes dans la séquence
    		# donc on récupère la ligne dans la variable $sequence
    		elsif ( ($seq) && ($line =~ /([\sa-z]+)\d+/))
    		{
    			$sequence.= $1; 
    			$sequence =~ tr/acgt/ACGT/;
     
    		}
     
    	} 
     
    	# suppression des espaces 
    	$sequence =~ s/\s//g;	 
    	print OUT "\n$sequence\n";
    	close (FILE) || die "Impossible de fermer le fichier";
     
    }
     
    close (OUT)  || die "imposible de fermer le fichier"; 
    # ferme le répertoire
    closedir (DIR)  || die "Impossible de fermer le répertoire";

  5. #5
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Points : 12 469
    Points
    12 469
    Billets dans le blog
    1
    Par défaut
    Une petite erreur de logique. Ton test:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    	if($nomFichier eq "." or $nomFichier eq "..")
    	{
    		# permet de passer le fichier
    		next;
    	}
    doit être fait avant d'ouvrir le fichier, pas après.

    Aussi avant d'ouvrir le fichier j'ajouterais un test éliminant les répertoires ou tout ce qui n'est pas fichier:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    next unless -f $nomFichier;
    ce qui, du coup rend le test sur les noms "." et ".." inutile, car "." et '.." ne sont pas des fichiers mais des répertoires.

    Il me semble qu'il y a une erreur de logique (si j'en crois le commentaire) ici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    		elsif ($line =~ m/^SQ/)
    		{
    			$seq = 1;
    		}
     
    		# si $seq est à 1, cela signifie que nous sommes dans la séquence
    		# donc on récupère la ligne dans la variable $sequence
    		elsif ( ($seq) && ($line =~ /([\sa-z]+)\d+/))
    		{
    			$sequence.= $1; 
    			$sequence =~ tr/acgt/ACGT/;
     
    		}
    mais ce n'est pas cela qui ferait partir ton programme dans une boucle infinie. Si $seq est à 1, tu ne rentres pas dans le elsif qui suit, du moins pas sur la même ligne. Mais je ne suis pas sûr de comprendre ton intention dans ce code.

    Essaie déjà de corriger ces trucs, et vois si ça change quelque chose.

  6. #6
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2016
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2016
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Merci Lolo78,

    Je prend note de tes conseilles je vais modifier mon code en conséquence.
    Je me suis rendu compte cette après midi, qu'en faite certaine de mes séquence étaient des génomes complet donc c'est pour ça que cela prenait beaucoup de temps, je n'avais pas de boucle infinie.
    Encore merci pour d'avoir prit le temps de regarder mon programme

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [XL-2003] Problème de boucle infinie
    Par SkyCorp dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 17/11/2011, 00h27
  2. Problème de boucle infinie
    Par Yachas dans le forum Général Python
    Réponses: 12
    Dernier message: 28/06/2011, 10h43
  3. Réponses: 6
    Dernier message: 15/11/2010, 09h47
  4. [Débutant]Problème de boucle infini
    Par Keldou dans le forum Octave
    Réponses: 1
    Dernier message: 21/04/2007, 17h20
  5. Problème de boucle infinie...
    Par anne-so dans le forum Langage
    Réponses: 1
    Dernier message: 25/04/2006, 14h10

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo