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 :

lire ecrire sur un fichier Excel


Sujet :

C#

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 142
    Points : 93
    Points
    93
    Par défaut lire ecrire sur un fichier Excel
    Bonjour,
    j'ai un web service qui balance une formule sous excel et enseuite récupère le résultat qui sera mis a disposition des clients (suite a des appels sur les WS).

    mon problème est dans le résultat retourné qui est de type "System.__ComObject"

    est ce que quelqu'un a une idée sur ce type de problème

    le code réalisé

    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
    [WebMethod]
        public string recupFromExcel() {
     
            Object oMissing  = System.Reflection.Missing.Value;
            Microsoft.Office.Interop.Excel.Application appex = new Microsoft.Office.Interop.Excel.ApplicationClass();
     
            Microsoft.Office.Interop.Excel._Workbook Classeur = appex.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
     
            Microsoft.Office.Interop.Excel._Worksheet Feuille = (Microsoft.Office.Interop.Excel._Worksheet)Classeur.ActiveSheet;
     
                    Feuille.Cells[1,2] = "test";
     
     
     
            return "cellule[1.2] = " + Feuille.Cells[1, 2];
        }
    le résultat attendu est "test" et retourné c'est System.__ComObject


    merci d'avance

  2. #2
    Rédacteur/Modérateur
    Avatar de Skalp
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 694
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 694
    Points : 2 927
    Points
    2 927
    Par défaut
    Essaye :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    return "cellule[1.2] = " + Feuille.Cells[1, 2].Value;
    // ou
    return "cellule[1.2] = " + Feuille.Cells[1, 2].Value2;

  3. #3
    Expert confirmé
    Avatar de debug
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    1 034
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 034
    Points : 4 093
    Points
    4 093
    Par défaut
    Bonjour,

    Dans un premier temps :
    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    Feuille.Cells[1,2] = "test";
    Ce n'est pas possible car la propriété "Cell" est en lecture seule (voir msdn )

    Pour écrire dans une cellule, le code doit ressembler à ça (de mémoire)
    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Microsoft.Office.Interop.Excel.Range rng = null;
    rng = Feuille.get_Range("A6", missing);
    rng.Value2 = "ma valeur";

    Pour lire ta cellule :
    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    return Feuille.Cells[1,2].Value2;

  4. #4
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Juin 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2006
    Messages : 142
    Points : 93
    Points
    93
    Par défaut
    merci

    juste une précision pour lire la valeur j'ai mi

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     return "cellule[1.2] = " + Feuille.get_Range("A1",oMissing).Value2;
    voici le code apres modification pour les suivants:

    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
    [WebMethod]
        public string recupFromExcel(String codevaleur) {
     
            Object oMissing  = System.Reflection.Missing.Value;
     
            Microsoft.Office.Interop.Excel.Application appex = new Microsoft.Office.Interop.Excel.ApplicationClass();
     
            Microsoft.Office.Interop.Excel._Workbook Classeur = appex.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
     
            Microsoft.Office.Interop.Excel._Worksheet Feuille = (Microsoft.Office.Interop.Excel._Worksheet)Classeur.ActiveSheet;
     
            Microsoft.Office.Interop.Excel.Range rng = null;
     
            rng = Feuille.get_Range("A1",oMissing);
     
            rng.Value2 = codevaleur;
     
     
     
            return "cellule[1.2] = " + Feuille.get_Range("A1",oMissing).Value2;
        }
    merci encore

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

Discussions similaires

  1. Lire/Ecrire sur un fichier d'un autre disque
    Par gabrielS dans le forum Débuter
    Réponses: 1
    Dernier message: 16/07/2013, 16h35
  2. Ecrire sur un fichier Excel, par du code C#
    Par hazem2410 dans le forum C#
    Réponses: 3
    Dernier message: 31/05/2011, 11h19
  3. Réponses: 2
    Dernier message: 27/05/2011, 09h27
  4. lire/ ecrire dans un fichier excel
    Par simpatico dans le forum C#
    Réponses: 5
    Dernier message: 01/04/2009, 14h47
  5. Lire/Ecrire dans un fichier excel
    Par toutounesan dans le forum C++
    Réponses: 5
    Dernier message: 14/09/2007, 22h07

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