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

C# Discussion :

Utiliser une dll C# avec vba


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 7
    Par défaut Utiliser une dll C# avec vba
    Bonjour,

    Je cherche a utiliser une dll codée depuis visual C# avec vba excel.
    J'utilise pour le moment un code simple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    namespace Mylibrary
    {
        public class SoapClass
        {
            public string test()
            {
               return ("hello");
            }
        }
    }
    J'ai donc inscrit ma bibliotheque de classe pour COM interop, je rend l'assembly visible par COM.
    Ensuite j'utilise RegAsm pour ajouter une reference au registre, je signe l'assembly et je l'ajoute au GAC.

    Puis j'instancie ma classe avec ce code vba:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Test()
     
        Dim sc_Liasse As SoapClass
        Set sc_Liasse = New SoapClass
     
    End Sub
    Mon probleme se pose lors de l'instanciation "set sc_Liasse = New SoapClass",
    J'ai une erreur d'execution :
    file or assembly name Mylibrary, or one of its dependencies, was not found.
    J'ai beau chercher, je ne vois pas d'ou vient le probleme.
    Merci d'avance pour vos reponses.

  2. #2
    Rédacteur

    Avatar de Jean-Michel Ormes
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juillet 2007
    Messages
    1 838
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Services à domicile

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 838
    Par défaut
    Il manque peut-être un :

    dans ton code vba

  3. #3
    Membre Expert
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Par défaut
    Il faut ajouter une référence au composant COM au projet VBA.

    Outils > Références, cocher dans la liste le composant COM voulu ou "Parcourir..." puis OK.

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 7
    Par défaut
    Désolé Kaidan j'avais oublié de preciser que j'avais déjà ajouté la reference "Mylibrary.tlb" a mon projet VBA.
    Ensuite, Jmichou972, la commande "using" s'utilise tres bien en C# mais en VBA je ne pense pas.

    Merci pour vos reponses, je continue de chercher.

  5. #5
    Membre Expert
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Par défaut
    Si tu utilises la lib de la GAC depuis une application C#, ça fonctionne ou pas ? sans COM avec avec COM ?

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 7
    Par défaut
    Depuis une application C# sur visual studio, ca fonctionne tres bien, que ce soit ma dll COM, une reference .NET ou une reference COM.

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

Discussions similaires

  1. Comment utiliser une dll avec VBA
    Par Nicolas_Aplus dans le forum Général VBA
    Réponses: 2
    Dernier message: 14/05/2013, 17h46
  2. utiliser une dll system32 avec un projet Windows Form
    Par gabouche dans le forum C++/CLI
    Réponses: 3
    Dernier message: 08/06/2012, 16h03
  3. Utiliser une .dll C# avec Ruby
    Par DmitryFane dans le forum Ruby
    Réponses: 3
    Dernier message: 29/07/2010, 11h22
  4. Utiliser une dll C# avec delphi
    Par Gruick dans le forum Débuter
    Réponses: 8
    Dernier message: 19/06/2008, 10h23
  5. Utiliser une DLL Delphi avec C#
    Par h8ciz dans le forum Windows Forms
    Réponses: 3
    Dernier message: 27/09/2007, 16h46

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