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

R Discussion :

Faire un split sans modifier la taille de la liste


Sujet :

R

  1. #1
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 37
    Points : 43
    Points
    43
    Par défaut Faire un split sans modifier la taille de la liste
    Bonjour à tous;
    Je sollicite votre matière grise pour solutionner un problème que je n'arrive pas à résoudre.
    J'ai une liste de 10 noms dont 4 sont composés.
    Le but est de faire un split dessus en ne gardant que le premier élément pour ne pas changer la taille de la liste:
    Par exemple: SPLIT("Marie José", "Fabienne", "France Galle", "Ludo") -> Marie, Fabienne, France, Ludo

    J'utilise la fonction strsplit() mais ça ne résous pas mon problème.

    Quelqu'un a la solution?
    Merci d'avance

  2. #2
    Membre éclairé
    Homme Profil pro
    Ingénieur de recherche
    Inscrit en
    Janvier 2012
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur de recherche
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 325
    Points : 888
    Points
    888
    Par défaut
    Utilise les expressions régulières.
    Il y a plusieurs façon de faire, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    noms = c("Marie José", "Fabienne", "France Galle", "Ludo")
    gsub(" .+","",noms)

  3. #3
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 37
    Points : 43
    Points
    43
    Par défaut
    Merci Theta pour votre réponse
    Effectivement votre code fonctionne mais ça ne corrige pas mon problème.
    En fait en récupérant des données sur le net, je déplore l'apparition de caractères spéciaux:
    Noms
    [1,] "Monsieur Royal"
    [2,] "Atilla"
    [3,] "Prince d'Aumone"
    [4,] "Master Planner"
    [5,] "Alasdair\n\t\t\t\n\t\t\t"
    [6,] "Nomos"
    [7,] "Stylish Sky"
    [8,] "Sheer Power\n\t\t\t\n\t\t\t"
    [9,] "Firefoot"
    [10,] "Niebieski"
    [11,] "Le Bouscot"
    [12,] "Rivolochop"

    Mon souci réel est de me débarrasser des "\n\t"; Excusez-moi, j'ai mal formulé mon besoin.
    J'ai tenté un: Noms <- strsplit(Noms, "\n.+") mais votre expression régulière ne passe pas, j'ai une erreur

    MAJ: Apparemment il s'agirait d'"espace sans chasse"

  4. #4
    Membre éclairé
    Homme Profil pro
    Ingénieur de recherche
    Inscrit en
    Janvier 2012
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur de recherche
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 325
    Points : 888
    Points
    888
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    gsub("\t|\n","",prenoms)

  5. #5
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 37
    Points : 43
    Points
    43
    Par défaut
    Ouf! Quel soulagement!
    Encore merci Théta, ce fût une petite frappe pour vous mais des cachets d'aspirines en moins pour moi!
    J'irais droit au but la prochaine fois
    God bless

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 07/07/2012, 21h09
  2. Réponses: 1
    Dernier message: 10/05/2008, 13h00
  3. Réponses: 7
    Dernier message: 23/01/2008, 23h36
  4. Réponses: 1
    Dernier message: 12/09/2005, 14h31
  5. Réponses: 5
    Dernier message: 27/11/2002, 14h08

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