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 :

Importer en filtrant une liste de valeur avec dbGetQuery


Sujet :

R

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2017
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2017
    Messages : 34
    Points : 42
    Points
    42
    Par défaut Importer en filtrant une liste de valeur avec dbGetQuery
    Bonjour,

    Je souhaiterai filtrer des valeurs sur une table que j'importe dans R à l'aide de DbGetQuery.
    Malheureusement, je peux pas effectuer mon filtre après car la base est trop volumineuse pour être importée et pour que je puisse effectuer mon filtre sur certaine valeur ensuite.

    déroulement de mon code:
    Première étape: j'édite mon query avec une requête SQL

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    query = "Select * from ma_table where mes_valeur = 'valeur_1' OR ....   'valeur_N'"
    Deuxième étape: j'importe la table

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ma_base = dbgetquery(my_db, query)
    Seulement, j'aurai besoin de pouvoir mettre dans mon query une liste (qui est déjà présente dans mon interface), je ne peux pas la recopier à la main car elle est beaucoup trop longue.

    Je vous remercie d'avance pour vos réponses

  2. #2
    Modératrice

    Femme Profil pro
    Statisticienne, Fondatrice de la société DACTA
    Inscrit en
    Juin 2010
    Messages
    893
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Statisticienne, Fondatrice de la société DACTA

    Informations forums :
    Inscription : Juin 2010
    Messages : 893
    Points : 2 673
    Points
    2 673
    Par défaut
    Bonjour,

    Voir du côté de la fonction "paste".
    Par exemple, quelque chose sur ce modèle (à adapter) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ma_liste <- c("valeur_1", ..., "valeur_N")
     
    query = paste0("Select * from ma_table where mes_valeur = ",  paste(ma_liste, collapse = " OR "))
    HTH !


    Cordialement,


    A.D.

    Forum R
    Fournir le code utilisé (pensez aux balises code !), les packages nécessaires, ainsi qu'un court mais représentatif extrait du jeu de données et les éventuels messages d'erreur.
    Recherche d'informations concernant R : RSiteSearch / tutoriels : http://r.developpez.com/cours/ .

    Pensez également au bouton "Résolu" et à voter (en bas à droite des messages) lorsque vous avez obtenu une réponse satisfaisante.

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2017
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2017
    Messages : 34
    Points : 42
    Points
    42
    Par défaut
    Super, j'ai modifié un peu le code et ça fonctionne !

    Du coup le code utilisé c'est

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    ma_liste <- c("valeur_1", ..., "valeur_N")
     
    query_1 = paste0("Select * from ma_table where mes_valeur = ' ",  paste(ma_liste, collapse = " OR mes_valeur=' "))
    query_2 = " ' "
     
    query = paste(query_1, query_2, sep="")
    Merci beaucoup pour le paste ! problème résolu

  4. #4
    Modératrice

    Femme Profil pro
    Statisticienne, Fondatrice de la société DACTA
    Inscrit en
    Juin 2010
    Messages
    893
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Statisticienne, Fondatrice de la société DACTA

    Informations forums :
    Inscription : Juin 2010
    Messages : 893
    Points : 2 673
    Points
    2 673
    Par défaut
    Bonjour,

    Ravie d'avoir pu aider

    Deux petites infos complémentaires (et utiles je pense ^^) :

    • On peut concaténer plus de 2 éléments avec un seul appel à "paste" : paste("a", "b", "c") .
    • La commande : paste("a", "b", sep ="") est équivalente à : paste0("a", "b")


    Bonne continuation !


    Cordialement,


    A.D.

    Forum R
    Fournir le code utilisé (pensez aux balises code !), les packages nécessaires, ainsi qu'un court mais représentatif extrait du jeu de données et les éventuels messages d'erreur.
    Recherche d'informations concernant R : RSiteSearch / tutoriels : http://r.developpez.com/cours/ .

    Pensez également au bouton "Résolu" et à voter (en bas à droite des messages) lorsque vous avez obtenu une réponse satisfaisante.

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 11/01/2014, 12h16
  2. [2.x] Supprimer une liste de valeur avec un Query Builder
    Par pmithrandir dans le forum Symfony
    Réponses: 1
    Dernier message: 02/06/2013, 20h09
  3. import/export d'une liste avec stsadm
    Par Benzeghiba dans le forum SharePoint
    Réponses: 1
    Dernier message: 08/09/2008, 12h11
  4. [MySQL] requête avec une contrainte d'exclusion portant sur une liste de valeurs
    Par vincounet dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 25/08/2008, 14h54
  5. ORACLE : pseudo-table avec une liste de valeurs
    Par LEPTMR dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/11/2006, 17h02

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