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 :

perte de données avec transfertspreadsheet [AC-2016]


Sujet :

VBA Access

  1. #1
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut perte de données avec transfertspreadsheet
    Bonjour,
    j'importe une feuille Excel généré par un logiciel pro, qui comporte un champ calculé (au lieu d'avoir le mot "voiture" dans le champ, par exemple, j'ai la formule Ce champ est primordial pour l'outil que je développe, et malheureusement à l'import c'est la valeur "0" qui remonte.
    Suis-je obligé de manipuler le tableur avant import ? (j'ai vu ceci : https://www.developpez.net/forums/d1...-excel-import/ mais c'est pour l'instant au delà de mes compétences)
    Ou connaissez-vous une astuce pour contourner ce problème ?
    Merci à vous !

  2. #2
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 294
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    J'ai créé un classeur Excel avec des formules de ce type
    J'ai importé ce classeur dans une table access (onglet Données externes - Nouvelle source de données - a partir d'un fichier - Excel) et je n'ai pas eu de soucis
    Quelle est votre méthode d'import ?

    Edit : Quel est le format du fichier Excel, également, xls, xlsx, xlsm...

  3. #3
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    la feuille est un xlsx
    attention on parle d'un import en vba
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DoCmd.TransferSpreadsheet acImport, , "T021_Dernière_Exportation_CLCA", _

  4. #4
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 294
    Billets dans le blog
    2
    Par défaut
    Re,

    DoCmd.TransferSpreadsheet a un 2ème argument AcSpreadSheetType, avez-vous essayé en le renseignant ?

    https://learn.microsoft.com/fr-fr/of...ferspreadsheet

  5. #5
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    je n'avais pas pensé à cette option...
    mais pareil, en ajoutant acSpreadsheetTypeExcel12, toujours mes 0

  6. #6
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 294
    Billets dans le blog
    2
    Par défaut
    Re,

    Pouvez-vous nous fournir une version du fichier Excel (sans données confidentielles) qui poserait problème ?

  7. #7
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    J'avais quelques scrupules à l'envoyer tel quel, j'ai voulu anonymer un peu mon tableur, l'allèger (~2000 lignes)...
    Bref, en supprimant simplement des lignes (version modifié : 30 lignes) ça passe ! c'est une piste...?

  8. #8
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 294
    Billets dans le blog
    2
    Par défaut
    Re,

    Oui, c'est une piste
    En modifiant le fichier et en l'enregistrant, vous avez probablement modifié son format (mis à jour son format vers la dernière version des fichiers Excel, donc probablement Excel 2016) et d'un coup ça passe
    Une autre piste est que vous aviez dans les données effacées une donnée corrompue particulière qui posait soucis
    A l'aveugle je ne sais pas trop, mais à fouiller

    Je suppose que votre fichier a donc un format pas tout à fait de la dernière version d'Excel, donc je tenterais avec le 2ème argument de TransferSpreadsheet avec des valeurs plus ancienne que Excel12, pour voir si ça passe avec les autres valeurs

  9. #9
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    j'ai testé tous les paramètres SheetType sans succès.
    En revanche, effectivement en ouvrant et enregistrant sous un autre nom, ça passe.
    Format foireux, ça ne m'étonne pas vu l'origine de l feuille excel...
    Je crois que je n'ai pas d'autre choix que d'automatiser une procédure de réenregistrement avant l'import...
    Merci de ton aide quoi qu'il en soit

  10. #10
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 294
    Billets dans le blog
    2
    Par défaut
    Re,

    Content qu'on ait identifié la source du problème
    Voir peut-être avec l'outil qui génère les fichiers s'il y a possibilité de modifier leur format d'export...

  11. #11
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    Effectivement j'étais sur cette piste, m'enfin les formats proposés sont pas très explicites, y'a du tâtonnement en perspective...
    Nom : Mozilla Firef.jpg
Affichages : 88
Taille : 32,8 Ko

  12. #12
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 294
    Billets dans le blog
    2
    Par défaut
    Re,

    En exportant en CSV ou en TXT, il n'y aura pas de soucis de format, normalement
    il faudra utiliser DoCmd.TransferText, je pense

  13. #13
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    le problème du csv ou du txt c'est qu'il faut créer soit-même les conditions d'importation (codage, séparateur...).
    https://www.developpez.net/forums/d2...ation-csv-vba/
    Mais ça vaut peut-être le coup...

  14. #14
    Membre confirmé
    Homme Profil pro
    utilisateur Access
    Inscrit en
    Janvier 2013
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : utilisateur Access
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2013
    Messages : 72
    Par défaut
    j'ai trouvé une fonction qui permet de réenregistrer le fichier excel avant l'import, ça règle le problème :

    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
    Function ImporterEtReenregistrerExcel(cheminFichier As String, nomTable As String) As Boolean
        On Error GoTo Erreur
     
        Dim xlApp As Object
        Dim xlWorkbook As Object
     
        ' 1. Ouvrir et réenregistrer le fichier Excel
        Set xlApp = CreateObject("Excel.Application")
        xlApp.Visible = False
        Set xlWorkbook = xlApp.Workbooks.Open(cheminFichier)
        xlWorkbook.Save
        xlWorkbook.Close
        xlApp.Quit
        Set xlWorkbook = Nothing
        Set xlApp = Nothing
     
        ' 2. Importer le fichier dans Access
        DoCmd.TransferSpreadsheet _
            TransferType:=acImport, _
            SpreadsheetType:=acSpreadsheetTypeExcel12Xml, _
            TableName:=nomTable, _
            FileName:=cheminFichier, _
            HasFieldNames:=True
     
        ImporterEtReenregistrerExcel = True
        Exit Function
     
    Erreur:
        MsgBox "Erreur : " & Err.Description, vbCritical
        ImporterEtReenregistrerExcel = False
    End Function

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

Discussions similaires

  1. Pertes de mémoire avec Rave
    Par stepschn dans le forum Delphi
    Réponses: 8
    Dernier message: 15/10/2006, 12h18
  2. creer connexion base de donné avec dbedit eclipse
    Par youcef81 dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 22/07/2006, 18h37
  3. création nouveau base de donné avec oracle
    Par awax dans le forum Oracle
    Réponses: 1
    Dernier message: 14/04/2006, 01h44
  4. Perte de données avec requete UNION
    Par askan dans le forum Access
    Réponses: 3
    Dernier message: 02/02/2006, 16h49
  5. Installation et perte d'icône avec Firebird
    Par SebCBien dans le forum Applications et environnements graphiques
    Réponses: 22
    Dernier message: 31/10/2004, 17h46

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