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

API, COM et SDKs Delphi Discussion :

[XLL] Comment résoudre "=R1C1" en la valeur de la cellule ?


Sujet :

API, COM et SDKs Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Expert éminent
    Avatar de Paul TOTH
    Homme Profil pro
    Freelance
    Inscrit en
    Novembre 2002
    Messages
    8 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Freelance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2002
    Messages : 8 964
    Par défaut [XLL] Comment résoudre "=R1C1" en la valeur de la cellule ?
    Bonjour,

    je travaille sur un Add-in Excel, une DLL Delphi renommée en XLL

    dans xlAutoOpen j'ai déclaré une toolbar avec un bouton, des fonctions...avec la fonction callback Excel4v() de XLCall32.dll

    un des boutons m'ouvre une fenêtre Wizard de mon cru pour définir une fonction.

    j'ai une zone qui accepte une référence de cellule qui me retourne "R1C1" quand je clique sur la celulle A1...sauf que dans la suite de mon Wizard j'ai besoin de la valeur de cette celulle !

    Je pensais utiliser xlfEvaluate sur "=R1C1" mais il me retourne xlErrValue

    Je peux coller la fonction dans une cellule pour en lire la valeur, mais ça m'embête de modifier le tableau comme ça...surtout qu'il faut pas que je tombe sur la cellule référencée !!!

    Quelqu'un a-t-il une autre idée ?

    Merci
    Developpez.com: Mes articles, forum FlashPascal
    Entreprise: Execute SARL
    Le Store Excute Store

  2. #2
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 491
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 491
    Par défaut
    salut paul,


    methode ou
    sinon

    PS : Comment va la capital ?

    @+ Phil

  3. #3
    Membre émérite

    Profil pro
    Inscrit en
    Mai 2003
    Messages
    582
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2003
    Messages : 582
    Par défaut
    est-ce que le = est requis xlfEvaluate...?
    est-ce que le type de reference est valide? Format A1 ou R1C1?
    que donne xlfEvaluate avec 'A1'?
    on peut changer de format de reference avec
    ConvertFormula()...
    Comment dupliquer un disque...ça vous intéresse?
    Tutoriel et code source delphi ici

  4. #4
    Expert éminent
    Avatar de Paul TOTH
    Homme Profil pro
    Freelance
    Inscrit en
    Novembre 2002
    Messages
    8 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Freelance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2002
    Messages : 8 964
    Par défaut
    Hello messieurs

    alors le problème c'est que je ne sais pas à priori ce que j'ai comme référence, j'ai une fiche Delphi invoqué par un bouton d'une toolbar personnalisée dont les composants sont "excellisés" (suivant un principe que je n'ai pas encore exploré) du coup mon TEdit possède un bouton qui permet quand on clique dessus de sélectionner une plage de cellules Excel, cela s'affiche sous la forme =$A1 par exemple, mais au niveau du composant je récupère ensuite le texte "R1C1".

    dans le code actuel, le texte est placé comme formule dans la cellule active pour en lire la valeur (avec sauvegarde de l'ancienne valeur de la cellule et restitution après coup)...

    Alors en effet j'ai testé un xlfEvaluate de "=!A1" et ça me renvoi non pas le texte mais une référence vers la celulle (xltypeSRef) mais je peux contourner le problème avec un "=CLEAN(!A1)" qui me renvoie un xltypeStr...ce que je veux au final.

    Mais pas moyen de passer de R1C1 à A1 (que je ne veux surtout pas traiter à la main !).

    Sinon la capitale ça se passe bien

    j'ai des horaires méchamment plus intenses que dans la fonction publique, mais pour l'instant (3 semaines) je supporte bien C'est pas tant le boulot (Delphi 5) que les 1h de Métro+RER matin et soir qui sont un peu pénibles

    Paul@Paris
    Developpez.com: Mes articles, forum FlashPascal
    Entreprise: Execute SARL
    Le Store Excute Store

Discussions similaires

  1. Réponses: 1
    Dernier message: 10/04/2014, 07h22
  2. [XL-2000] Comment copier puis coller x fois ? (x = valeur de la cellule)
    Par wyzer dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 23/03/2010, 13h32

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