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

Langage Perl Discussion :

parcourir un objet


Sujet :

Langage Perl

  1. #1
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut parcourir un objet
    Bonjour,

    J'ai un obje $seq contenant plusieurs sous-objets (corrigez moi si mon vocabulaire est incorrect)


    Voici 2 des nombreux sous-objets de mon objet $seq
    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
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
                                     bless( {
                                              '_source_tag' => 'EMBL/GenBank/SwissProt',
                                              '_gsf_seq' => $VAR1->{'primary_seq'},
                                              '_location' => bless( {
                                                                      '_strand' => -1,
                                                                      '_seqid' => 'CP000733',
                                                                      '_location_type' => 'EXACT',
                                                                      '_start' => '1892972',
                                                                      '_end' => '1893048',
                                                                      '_root_verbose' => 0
                                                                    }, 'Bio::Location::Simple' ),
                                              '_gsf_seq_id' => 'CP000733',
                                              '_primary_tag' => 'tRNA',
                                              'annotation' => bless( {
                                                                       '_typemap' => bless( {
                                                                                              '_type' => {
                                                                                                           'locus_tag' => 'Bio::Annotation::SimpleValue',
                                                                                                           'comment' => 'Bio::Annotation::Comment',
                                                                                                           'reference' => 'Bio::Annotation::Reference',
                                                                                                           'product' => 'Bio::Annotation::SimpleValue',
                                                                                                           'dblink' => 'Bio::Annotation::DBLink',
                                                                                                           'old_locus_tag' => 'Bio::Annotation::SimpleValue'
                                                                                                         }
                                                                                            }, 'Bio::Annotation::TypeManager' ),
                                                                       '_annotation' => {
                                                                                          'locus_tag' => [
                                                                                                           bless( {
                                                                                                                    'value' => 'CBUD_1916'
                                                                                                                  }, 'Bio::Annotation::SimpleValue' )
                                                                                                         ],
                                                                                          'product' => [
                                                                                                         bless( {
                                                                                                                  'value' => 'tRNA-Ile'
                                                                                                                }, 'Bio::Annotation::SimpleValue' )
                                                                                                       ],
                                                                                          'old_locus_tag' => [
                                                                                                               bless( {
                                                                                                                        'value' => 'COXBU7E912_1916'
                                                                                                                      }, 'Bio::Annotation::SimpleValue' )
                                                                                                             ]
                                                                                        }
                                                                     }, 'Bio::Annotation::Collection' )
                                            }, 'Bio::SeqFeature::Generic' ),                                 bless( {
                                              '_source_tag' => 'EMBL/GenBank/SwissProt',
                                              '_gsf_seq' => $VAR1->{'primary_seq'},
                                              '_location' => bless( {
                                                                      '_strand' => -1,
                                                                      '_seqid' => 'CP000733',
                                                                      '_location_type' => 'EXACT',
                                                                      '_start' => '1893237',
                                                                      '_end' => '1894693',
                                                                      '_root_verbose' => 0
                                                                    }, 'Bio::Location::Simple' ),
                                              '_gsf_seq_id' => 'CP000733',
                                              '_primary_tag' => 'rRNA',
                                              'annotation' => bless( {
                                                                       '_typemap' => bless( {
                                                                                              '_type' => {
                                                                                                           'locus_tag' => 'Bio::Annotation::SimpleValue',
                                                                                                           'comment' => 'Bio::Annotation::Comment',
                                                                                                           'reference' => 'Bio::Annotation::Reference',
                                                                                                           'gene' => 'Bio::Annotation::SimpleValue',
                                                                                                           'product' => 'Bio::Annotation::SimpleValue',
                                                                                                           'dblink' => 'Bio::Annotation::DBLink',
                                                                                                           'old_locus_tag' => 'Bio::Annotation::SimpleValue'
                                                                                                         }
                                                                                            }, 'Bio::Annotation::TypeManager' ),
                                                                       '_annotation' => {
                                                                                          'locus_tag' => [
                                                                                                           bless( {
                                                                                                                    'value' => 'CBUD_1917'
                                                                                                                  }, 'Bio::Annotation::SimpleValue' )
                                                                                                         ],
                                                                                          'gene' => [
                                                                                                      bless( {
                                                                                                               'value' => 'rrsA'
                                                                                                             }, 'Bio::Annotation::SimpleValue' )
                                                                                                    ],
                                                                                          'product' => [
                                                                                                         bless( {
                                                                                                                  'value' => '16S ribosomal RNA'
                                                                                                                }, 'Bio::Annotation::SimpleValue' )
                                                                                                       ],
                                                                                          'old_locus_tag' => [
                                                                                                               bless( {
                                                                                                                        'value' => 'COXBU7E912_1917'
                                                                                                                      }, 'Bio::Annotation::SimpleValue' )
                                                                                                             ]
                                                                                        }
                                                                     }, 'Bio::Annotation::Collection' )
                                            }, 'Bio::SeqFeature::Generic' ),
    J'aimerais parcourir ces sous-objets et récupérer des informations. Je recherche la position de départ du produit '23S ribosomal RNA'. Un seul des sous-objets possède cette valeur comme produit. Dans cet exemple, je voudrais récupérer la valeur 1893237 de 'start'.

    Je ne sais pas comment procéder. J'ai essayé avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
                foreach my $feature ($seq->get_SeqFeatures){
                    if($feature->primary_tag eq 'rRNA') {
                        if($feature->has_tag('product') eq '23S ribosomal RNA') {
                            my $product = $feature->get_tag_values('product');
                            print "$product\n";
                        }
                    }
                }
    mais je ne sais pas où indiquer que le tag 'annotation' doit être utilisé.


    Ou alors faire quelque chose comme ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
            my @Features = $seq->get_SeqFeatures;
     
            $NombreObjets = @Features;
            print "Nbr objets = $NombreObjets\n";
     
     
            for ($s=0; $s<$NombreObjets; $s++){
     
                    my $Features = $Features[$s];  # avance block par block
                    foreach my $k (keys %$Features)
                    {
                             ...

    Ce n'est pas très clair car je ne sais pas quels termes utiliser, n'hésitez pas à me poser des questions.


    Merci de votre aide,

  2. #2
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut
    J'ai fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    print Dumper $feature->get_tag_values('product');
    et j'obtiens
    $VAR1 = '26S ribosomal RNA';
    Y a-t'il moyen de récupérer 26S ribosomal RNA plus facilement que par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                            my $rib;
                            foreach  ($feature->get_tag_values('product')){$rib = $_;};

    Avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    print Dumper $feature->location;
    J'obtiens
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $VAR1 = bless( {
                     '_strand' => 1,
                     '_seqid' => 'CP000733',
                     '_location_type' => 'EXACT',
                     '_start' => '1096955',
                     '_end' => '1097233',
                     '_root_verbose' => 0
                   }, 'Bio::Location::Simple' );
    Je récupère start avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
                        foreach my $hash ($feature->location){
                            print ${$hash}{'_start'}."\n";
                        }
    Est-ce correct? En tous cas, cela semble fonctionner.

    Merci de votre aide,

  3. #3
    Membre actif Avatar de CKLN00
    Homme Profil pro
    Bioinformaticien Java/Perl
    Inscrit en
    Avril 2008
    Messages
    210
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Bioinformaticien Java/Perl
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2008
    Messages : 210
    Points : 263
    Points
    263
    Par défaut
    bha pour le coup de RIEN xD !

  4. #4
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut
    Je parlais comme aide, de vos conseils et commentaires utile ("utiles" ... n'est ce pas CKLN00) au sujet de mes morceaux de script

    Merci,

  5. #5
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Pourquoi est-ce que tu mets des foreach() partout ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $rib = $feature->get_tag_values('product');
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $start = $feature->location->{'_start'};
    marchent tout aussi bien, non ?

    --
    Jedaï

  6. #6
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut
    Oui, merci. Je testerai demain matin au labo. Cela me paraissait bien compliqué avec foreach mais je ne voyais pas comment faire d'autre .
    ... le pire, c'est que pour 'product', je l'avais bien fait sans foreach, ça devait être la fatigue.

    Merci,

  7. #7
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut
    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
                foreach my $feature ($seq->get_SeqFeatures){
                    my $start = $feature->location->{'_start'};
                    my $end = $feature->location->{'_end'};
                    if($feature->primary_tag =~ /rRNA/) {
                        my @tags = $feature->get_all_tags;
                        if($feature->has_tag('product') ) {
                            my $rib;
                            #foreach  ($feature->get_tag_values('product')){$rib = $_;}
                            $rib = $feature->get_tag_values('product');
                            if(($rib =~ /16S/)||($rib =~ /23S/)){
                                print "$rib\tstart : $start\tend $end\n";
     
                            }
                        }
                    }
                }

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $start = $feature->location->{'_start'};
    Cela fonctionne bien

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $rib = $feature->get_tag_values('product');
    Mais cela ne fonctionne pas



    Je me demandais aussi si le module PDL pourrait optimaliser ce script-ci?
    http://search.cpan.org/dist/PDL/Basic/PDL.pm

    En fait, chaque objet est énorme. J'ai imprimé le plus petit par un print $out_file Dumper $objet et il fait 257361 lignes.
    Je dois récupérer dans ces objet, la séquence ADN, les index de début et de fin de la sous-séquence à extraire (par un substring). Les séquences à récupérer sont des génomes bactériens entiers et font parfois plus de 2 millions de nucléotides.


    Avec une telle longueur de caractères, est-il préférable d'utiliser une référence sur mon scalaire?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
                my $genome = $seq->seq;
                my $ref_genome = \$genome;
    Merci beaucoup,

  8. #8
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut
    Voici le script simplifier, (dans le script original, j'effectue la requête sur une liste d'accession). Cela pourra peut-être aider quelqu'un.

    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
    use strict;
    use warnings;
    use Bio::DB::GenBank;
     
    my $db="nucleotide";
    my $gb = new Bio::DB::GenBank;
     
    my $accession = 'CP000733';
    print "\n\nRécupération de la sous-séquence 23S_16S de $accession\n\n";
    my $seq = $gb -> get_Seq_by_acc($accession);
    my $genome = $seq->seq;
    my $ref_genome = \$genome;
    my $start_23S;
    my $end_16S;
    foreach my $feature ($seq->get_SeqFeatures){
        my $start = $feature->location->{'_start'};
        my $end = $feature->location->{'_end'};
        if($feature->primary_tag =~ /rRNA/) {
            my @tags = $feature->get_all_tags;
            if($feature->has_tag('product') ) {
                my $rib;
                foreach  ($feature->get_tag_values('product')){$rib = $_;}
                if($rib =~ /16S/){
                    print "$rib\tstart : $start\tend $end\n";
                    $end_16S = $end;
                }
                elsif($rib =~ /23S/){
                    print "$rib\tstart : $start\tend $end\n";
                    $start_23S = $start;
                }
            }
        }
    }
    my $length = $end_16S - $start_23S + 1;
    my $sous_seq = substr(${$ref_genome}, $start_23S, $length);
    print "Sous-sequence $accession\tstart 23S : $start_23S\tend 16S : $end_16S\n\n";
    print ">Sous_seq_".$accession."\n".$sous_seq."\n";

  9. #9
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    A priori cela veut dire que la méthode renvoie bien un tableau, mais pourquoi ferait-elle cela s'il n'y a qu'une seule valeur dedans...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $rib = ($feature->get_tag_values('product'))[-1];
    devrait faire la même chose que ta boucle, mais je reste sceptique sur le sens de la manœuvre.

    --
    Jedaï

  10. #10
    Membre émérite
    Avatar de Jasmine80
    Femme Profil pro
    Bioinformaticienne
    Inscrit en
    Octobre 2006
    Messages
    3 157
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 44
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Bioinformaticienne
    Secteur : Santé

    Informations forums :
    Inscription : Octobre 2006
    Messages : 3 157
    Points : 2 673
    Points
    2 673
    Par défaut
    Oui, en effet cela fait la même chose. Merci pour ton aide.

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

Discussions similaires

  1. Parcourir un objet
    Par ragnarokr dans le forum C#
    Réponses: 17
    Dernier message: 01/06/2014, 18h42
  2. comment parcourir un objet json?
    Par aminaoussaleh dans le forum Développement Web en Java
    Réponses: 3
    Dernier message: 08/12/2009, 17h08
  3. [POO] parcourir un objet json avec une boucle for in
    Par bucheron007 dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 19/01/2009, 13h55
  4. Parcourir un objet Collection
    Par 3KyNoX dans le forum C#
    Réponses: 8
    Dernier message: 30/11/2008, 23h14
  5. Parcourir un objet
    Par Manitobaa dans le forum Windows Forms
    Réponses: 1
    Dernier message: 30/10/2008, 17h43

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