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

VBA Access Discussion :

import des espaces devant référence csv --> Access


Sujet :

VBA Access

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 7
    Points : 6
    Points
    6
    Par défaut import des espaces devant référence csv --> Access
    Bonjour,
    Sous Access2007, je n'arrive pas, en important les données à partir d'un fichier *.csv, à conserver le ou les espace(s) se trouvant au début d'une chaîne de caractère de format texte.

    Est-ce que quelqu'un sait faire ceci ?

    D'avance merci pour votre réponse !

    Vinz4444

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Tes chaînes de caractères sont-elles délimités par des " ou un autre caractères ?

    Si oui, il va sans doute falloir faire du code VBA qui va faire l'import à la place des routines de Access.

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 7
    Points : 6
    Points
    6
    Par défaut
    Non les chaînes sont séparées par des ; comme identifiant de colonnes dans le *.csv

    Il y a des espaces avant et après pour ce champ. Je ne veux récupérer que les espaces avant...

    Oui ça ne me dérange pas d'utiliser une macro VBA ou SQL dans Access mais je ne connais pas de fonctions capables de faire cela ?

    Une idée ?

  4. #4
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Fait un essai en ajoutant des délimiteurs de chaîne de caractères comme les guillemets et si cela marche voit si le logiciel qui te fourni le CSV peut les ajouter. C'est parfois une option disponible.

    Sinon il va falloir faire du code qui lit le fichier ligne à ligne et qui découpe sur les ";".
    On peut utiliser Split() pour cela qui génère un tableau d'éléments. Une fois le tableau créé il va falloir mettre les éléments 1 par 1 dans les champs correspondant. Bref c'est quand même pas mal de travail pour une lecture de fichier texte.

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  5. #5
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    salut marot_r et bienvenu vinz4444,

    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
    Sub ImportCSV()
        Source = "C:\temp\Classeur1.csv"
        Separateur = ";"
        Destination_table = "Classeur1"
        Destination_champs = "champ1,champ2,champ3,champ4"
        Destination_champs_type = Array("""", "", """", "#")    ' type: texte, numérique, texte, date
     
        Dim fs, f
        Set fs = CreateObject("Scripting.FileSystemObject")
        Set f = fs.OpenTextFile(Source, 1)
     
        DoCmd.SetWarnings False
        Do While f.AtEndOfStream <> True
            Champs = Split(Replace(Replace(f.ReadLine, "'", "''"), """", """"""), Separateur)
            For i = 0 To UBound(Champs)
                Champs(i) = Destination_champs_type(i) & Champs(i) & Destination_champs_type(i)
            Next i
            LeSQL = Join(Champs, ",")
            LeSQL = "INSERT INTO " & Destination_table & "(" & Destination_champs & ") VALUES (" & LeSQL & ")"
            DoCmd.RunSQL LeSQL
        Loop
        DoCmd.SetWarnings True
        f.Close
    End Sub
    la table doit exister préalablement, le type/nombre de champs correspondre, et tant qu'à faire que l'emplacement fichier soit correct...


  6. #6
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 331
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 331
    Points : 23 786
    Points
    23 786
    Par défaut
    Merci Vodiem pour cette éléguante solutions.

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 7
    Points : 6
    Points
    6
    Par défaut Au risque de passer pour un amateur...
    Bonjour,
    MERCI pour cette réponse !
    Cependant je ne suis pas informaticien et là je ne vois pas trop quoi faire avec ceci...
    C'est à coller dans une requête SQL dans ACCESS ?
    Est-ce que je peux avoir quelques infos sur comment ça fonctionne exactement (des lignes explicatives ?...).
    Vraiment désolé pour mon amateurisme...
    A bientôt j'espère...
    Vinz4444

  8. #8
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    merci marot_r, ca fait plaisir de connaitre des personnes qui savent apprécier du code.

    vinz4444, tu peux par exemple créer un bouton dans un formulaire et recopier ce code (sans les déclaration Sub... et End Sub) dans l'événement 'sur click'.
    adapte les 5 premières lignes à ton cas et test...

    ps: n'oublie pas que la table et sa structure doivent être préalablement crée.


  9. #9
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    Bonjour,

    Vodiem, dans un élan lyrique :
    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
    Sub ImportCSV()
        Source = "C:\temp\Classeur1.csv"
        Separateur = ";"
        Destination_table = "Classeur1"    Destination_champs = "champ1,champ2,champ3,champ4"
        Destination_champs_type = Array("""", "", """", "#")    ' type: texte, numérique, texte, date
        
        Dim fs, f
        Set fs = CreateObject("Scripting.FileSystemObject")
        Set f = fs.OpenTextFile(Source, 1)
        
        DoCmd.SetWarnings False
        Do While f.AtEndOfStream <> True
            Champs = Split(Replace(Replace(f.ReadLine, "'", "''"), """", """"""), Separateur)
            For i = 0 To UBound(Champs)
                Champs(i) = Destination_champs_type(i) & Champs(i) & Destination_champs_type(i)
            Next i
            LeSQL = Join(Champs, ",")
            LeSQL = "INSERT INTO " & Destination_table & "(" & Destination_champs & ") VALUES (" & LeSQL & ")"
            DoCmd.RunSQL LeSQL
        Loop
        DoCmd.SetWarnings True
        f.Close
    End Sub
    Mouais, pas parfait mais pas mal pour un p'tit jeune...

    @+

    Philippe

  10. #10
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    lol, ca fais plaisir de te revoir parmi nous Philippe !

    je te répond avec mon élan Lyrie que:
    la perfection te sied mieux qu'à moi... je préfère rester discret. ;p

Discussions similaires

  1. Réponses: 6
    Dernier message: 28/05/2008, 09h04
  2. importer des données Excel dans une BD Access
    Par lemerite dans le forum VBA Access
    Réponses: 3
    Dernier message: 19/02/2008, 13h34
  3. Réponses: 1
    Dernier message: 06/11/2007, 16h43
  4. Réponses: 5
    Dernier message: 20/06/2007, 14h11
  5. Importation des données d'un *.csv
    Par Baya44 dans le forum Access
    Réponses: 8
    Dernier message: 05/03/2007, 09h33

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