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

Macros et VBA Excel Discussion :

Récupérer une valeur via COM (avec une macro sur la cellule)


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé Avatar de a028762
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 419
    Points : 537
    Points
    537
    Par défaut Récupérer une valeur via COM (avec une macro sur la cellule)
    Bonjour,
    Je développe en PHP et utilise COM pour dialoguer avec EXCEL 2003.
    certains fichiers Excel que l'application PHP est susceptible de lire
    contiennent une macro nommée "Worksheet_DoubleClick"
    qui remplis la cellule de la date du jour quand on double-click sur la cellule.
    Tout ça est bel et bon, mais du cout, je récupère via COM non la valeur de la date, mais un objet dont le contenu ne peut être connu à priori.

    Quelqu'un connait-il ce problème et sais comment le contourner ?

  2. #2
    Membre confirmé Avatar de a028762
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 419
    Points : 537
    Points
    537
    Par défaut Bon, ben je transmets mon propre code (en cours de map)
    Code php : 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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    function LireCellule() {
        #                2 Formes d'utilisations
        #                1ère forme
        #    Adresse        Adresse d'une cellule de type "A8"
        #                2ème forme
        #                Adresse d'une cellule de type "$3$4"; (L3C4
        #    Ligne        Ligne de la cellule
        #    Colonne        Colonne de la cellule
     
        # --------------------------------------------------------------- Analyse des paramètres
        if (func_num_args() == 0) {                                        # Adresse vide
            $this->_Erreur = "L'adresse fournie est vide";
        } else {
            $this->_Erreur = "";                                        # Raz de l'erreur à priori
            $Exception = "com_exception";
            try {
                # ....................................................... Fournir l'Adresse en une seule variable
                if (func_num_args() == 1) {
                    $Adresse        = func_get_arg(0);        
                    $this->_Cellule = $this->_Feuille->Range($Adresse);
                } else {
                    # ................................................... Fournir l'Adresse en LIGNE et en COLONNE
                    $Ligne            = func_get_arg(0);
                    $Colonne        = func_get_arg(1);    
                    $this->_Cellule = $this->_Feuille->Cells($Ligne,$Colonne);
                }
                # ------------------------------------------------------- Récupération des données
                $Valeur        = $this->_Cellule->Value;                    # Lecture de la CELLULE ?
                if (is_object($Valeur)) {
                    #    $Comment    = $this->_Cellule->Comment;                    # Plus simple que Valeur ?
                    $Erreur        = $this->_Cellule->ShowErrors;
                    $Valeur2    = $this->_Cellule->Value2;                # Valeur non formatée
                    $Format     = $this->_Cellule->NumberFormat;        # Format de la cellule
                    if ($Format == "jj\\/mm\\/aaaa") {                    # Heure française
                        $Valeur = $Erreur;                                # C'est celle qu'on utilise alors
                    } else {
    #    OL    ETUDE en cours: Erreur de manipulation de ->ShowErrors en string
    #                    var_export($Erreur);
    #                    echo br;
    #                    var_export($Valeur2);
    #                    echo br;
    #                    echo "Format:".$Format.br;
    #                    echo "Onglet:".$this->_Onglet.br;
    #                    $this->_Erreur = "Objet COM (Onglet:".$this->_Onglet.") sur la cellule:".$Adresse.", analyse incomplète pour l'instant (Erreur:".$Erreur.")";        # A interpréter plus tard !
                        $this->_Erreur = "Objet COM (Onglet:".$this->_Onglet.") , erreur non récupérable dans la cellule ".$Adresse;     
                    }
                } else {
                    if (is_array($Valeur)) {
                        $Erreur        = $this->_Cellule->Value2;
                        $this->_Erreur = "Tableau COM (Onglet:".$this->_Onglet.") sur la cellule:".$Adresse.", analyse incomplète pour l'instant (Erreur:".$Erreur.")";    # A interpréter plus tard !
                    }
                }
            }
            catch (Exception $Exception) {                                # Gestion d'erreur COM
                $this->_Erreur = $Exception->getCode().", Message:".$Exception->getMessage()."; Fichier:".$Exception->getFile()."; ligne:".$Exception->getLine();
            }
        }    
        return $Valeur;
    }

Discussions similaires

  1. affecter une valeur via un userform à une variable d'une procédure
    Par panda78 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/07/2012, 10h58
  2. Réponses: 3
    Dernier message: 22/08/2010, 17h40
  3. Réponses: 10
    Dernier message: 04/11/2008, 14h30
  4. Réponses: 9
    Dernier message: 29/08/2008, 14h35
  5. Récupérer une valeur via un autre script
    Par Olivier Regnier dans le forum Langage
    Réponses: 2
    Dernier message: 14/11/2007, 10h12

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