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 :

Erreur 13 incompatibilité de type


Sujet :

VBA Access

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2016
    Messages : 28
    Points : 26
    Points
    26
    Par défaut Erreur 13 incompatibilité de type
    Bonjour tout le monde. Alors voici mon problème :
    Je travail sur access et j'ai developpé un module d'import d'un fichier excel dans une table de ma BD. Toutefois le fichier excel que je veux importer comporte une colonne avec des données que je veux scindé en 3 alors voici mon code VBA pour le moment qui génère une première colonne avec la partie des données de la colonne 1 qui m' interresse :


    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
        ' Initialiser les variables
        Set xlApp = CreateObject("Excel.Application")
        Set xlBook = xlApp.Workbooks.Open("C:\Users\Ayoub\Desktop\feuille2.xlsx")
     
        'insertion d'une colonne Medecin
        Range("B1").Select
     
        Selection.EntireColumn.Insert
        'xlSheet.Cells(1, 40).value = "ID medecin"
        For x = 2 To 267
            Cells(x, 2).Formula = "=LEFT(A" & x & ",FIND(" - ",A" & x & ")-1)"
     
     
            '"=left(A" & x & ", 1)"
            ' " WorksheetFunction.Left(A2, WorksheetFunction.Find(" - ", A2) - 1)"
            Next x
    "=left(A" & x & ", 1)" cette fonction fonctionne sans problème. Or celle ci : LEFT(A" & x & ",FIND(" - ",A" & x & ")-1)refuse de s’exécuter je ne comprend pas pourquoi. Si quelqu'un pouvait venir a mon secours ^^'. Le probleme semble venir du find.

  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
    Bonjour.

    C'est parce que tu essaye de faire une soustraction de chaîne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "=LEFT(A" & x & ",FIND(" [B]-[/B] ",A" & x & ")-1)"
    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
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 088
    Points : 5 204
    Points
    5 204
    Par défaut
    Bonjour,

    Pour qu'un " soit contenu dans une string et non son délimiteur, il faut le doubler
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cells(x, 2).Formula = "=LEFT(A" & x & ",FIND("" - "",A" & x & ")-1)"
    Utilisez Planet, gestion d'entreprise gratuite pour TPE / PME

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2016
    Messages
    28
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2016
    Messages : 28
    Points : 26
    Points
    26
    Par défaut
    OMG merci nico84 je suis trop con je galère depuis tout a l'heure a cause de ça quoi...

  5. #5
    Invité
    Invité(e)
    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
    Sub test()
    With CreateObject("Excel.Application")
        With xlApp.Workbooks.Open("C:\Users\Ayoub\Desktop\feuille2.xlsx")
            '.visible=true
            With .Sheets("Feuil1")
                .Range("B1").EntireColumn.Insert
                For x = 2 To 267
                     .Cells(x, 2).Formula = "=LEFT(A" & x & ",FIND("" - "",A" & x & ")-1)"
                Next
            End With
           ' .Close False
        End With
        '.Quit
    End With
    End Sub
    Dernière modification par Invité ; 21/10/2016 à 17h02.

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

Discussions similaires

  1. [A-07] Erreur n°13 : Incompatibilité de type
    Par Leimi dans le forum VBA Access
    Réponses: 2
    Dernier message: 17/03/2009, 11h15
  2. Erreur d'incompatibilité de types
    Par étoile de mer dans le forum Débuter
    Réponses: 27
    Dernier message: 01/06/2008, 17h14
  3. DLookup, Erreur d'incompatibilité de type (13)
    Par athos7776 dans le forum VBA Access
    Réponses: 5
    Dernier message: 08/08/2007, 17h25
  4. Erreur 13 : incompatibilité de type
    Par Donatelli dans le forum Access
    Réponses: 1
    Dernier message: 03/01/2007, 12h19
  5. [VBA-A] ADO - Erreur 13 Incompatibilité de Type
    Par db30 dans le forum VBA Access
    Réponses: 4
    Dernier message: 15/04/2006, 14h30

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