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

MATLAB Discussion :

Conversion nombre en alphabet Excel


Sujet :

MATLAB

  1. #1
    Membre expérimenté Avatar de lecteur1001
    Inscrit en
    Mai 2009
    Messages
    1 526
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 1 526
    Points : 1 554
    Points
    1 554
    Par défaut Conversion nombre en alphabet Excel
    Bonjour à tous,

    derrière cet objet de discussion peu clair, se cache un problème a priori très simple

    J'ai en ma possession plusieurs fichiers Excel contenant des enregistrements d'essai. Dans chacun de ceux-là, une seule colonne m'intéresse. Jusqu'à présent, j'utilisais donc simplement la fonction xlsread en lui fournissant les éléments nécessaires, dont la colonne souhaitée. Sauf que dans chacun de mes fichiers Excel, la colonne qui m'intéresse n'est pas toujours placée à la colonne E par exemple.
    J'ai donc eu l'idée de récupérer le contenu de la première ligne du fichier Excel (contenant les chaînes de caractères qui indiquent de quoi la colonne s'agit) puis de comparer ce que je recherche à chacun des éléments de cette ligne. Je connais donc l'indice de la colonne qui m'intéresse. SAUF QUE, les colonnes Excel sont des lettres, pas des nombres ! Je cherche donc une fonction qui convertisse un nombre en lettre. Par exemple :
    1 donne A ;
    5 donne D ;
    27 donne AA.
    En cherchant sur le net, je n'ai pas trouvé de fonction faisant cela. Je n'arrive pas non plus à créer un script me permettant de faire cette conversion.

    Est-ce que quelqu'un a une idée à mon problème svp ?

    Merci d'avance pour votre aide
    À lire avant de poster : qu'est ce qu'un ECM (Exemple Complet Minimal) ?
    Règles des forums LaTeX. Quand votre problème est réglé, mettez votre discussion en
    Pour débuter en LaTeX je conseille fortement Tout ce que vous avez toujours voulu savoir sur LaTeX sans jamais oser le demander (merci Woody Allen ), livre téléchargeable gratuitement ou en vente dans le commerce pour 15 €

  2. #2
    Membre expérimenté Avatar de lecteur1001
    Inscrit en
    Mai 2009
    Messages
    1 526
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 1 526
    Points : 1 554
    Points
    1 554
    Par défaut
    Citation Envoyé par lecteur1001 Voir le message
    Je n'arrive pas non plus à créer un script me permettant de faire cette conversion.
    Bon... j'ai trouvé tout seul ! Si ça peut servir à quelqu'un, voici :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    a = 26*3; % indice 
    nb = 26; % nombre de lettres dans l'alphabet
    i = 64; % décalage code ascii pour le A
    r = ceil(a/nb)-1;
    c = a+i-nb*r;
    if r==0    
        b = char(c);
    else
        b = [char(i+r) char(c)];
    end
    b
    Attention, ce code ne fonctionne que jusqu'à ZZ. Il est donc améliorable ! Avis aux amateurs.

    Voilà, merci quand même
    À lire avant de poster : qu'est ce qu'un ECM (Exemple Complet Minimal) ?
    Règles des forums LaTeX. Quand votre problème est réglé, mettez votre discussion en
    Pour débuter en LaTeX je conseille fortement Tout ce que vous avez toujours voulu savoir sur LaTeX sans jamais oser le demander (merci Woody Allen ), livre téléchargeable gratuitement ou en vente dans le commerce pour 15 €

  3. #3
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 882
    Points
    52 882
    Par défaut
    Citation Envoyé par lecteur1001 Voir le message
    Avis aux amateurs.
    Et à quoi ça sert que Dut se décarcasse ?

    => [Excel] Notation de référence de cellules

    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  4. #4
    Membre du Club
    Homme Profil pro
    Étudiant:chaque jour on aprend des choses ;)
    Inscrit en
    Septembre 2011
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Espagne

    Informations professionnelles :
    Activité : Étudiant:chaque jour on aprend des choses ;)
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2011
    Messages : 43
    Points : 68
    Points
    68
    Par défaut
    Bonjour,

    bienque j'ai vu que la disscusion est marquée comme 'Résolu', une petite apportation:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    %col_nombre est le nombre de colonne a traduire
    col_texte = regexprep([char(64+floor(col_nombre/26)),char(64+mod(col_nombre,26))],char(64),'')
    simplification de la conversion à une seule ligne, mais encore limité par ZZ comme colonne maxi.

  5. #5
    Membre expérimenté Avatar de lecteur1001
    Inscrit en
    Mai 2009
    Messages
    1 526
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 1 526
    Points : 1 554
    Points
    1 554
    Par défaut
    Heu....
    Rien compris ! Je n'ai toujours pas saisi ce que cette phrase signifie :
    Citation Envoyé par Dut Voir le message
    Deux fonctions permettant de convertir une référence d'une cellule ou d'une plage de cellules d'une feuille Excel contenue dans une chaine de caractères.
    Quand on parle de "conversion", on dit qu'on convertit quelque chose vers quelques chose d'autre. Là, je ne saisis pas.

    Citation Envoyé par KR4ZY_GUI Voir le message
    bienque j'ai vu que la disscusion est marquée comme 'Résolu', une petite apportation:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    %col_nombre est le nombre de colonne a traduire
    col_texte = regexprep([char(64+floor(col_nombre/26)),char(64+mod(col_nombre,26))],char(64),'')
    Merci de cette apport(ation), certes plus efficace et astucieuse !
    À lire avant de poster : qu'est ce qu'un ECM (Exemple Complet Minimal) ?
    Règles des forums LaTeX. Quand votre problème est réglé, mettez votre discussion en
    Pour débuter en LaTeX je conseille fortement Tout ce que vous avez toujours voulu savoir sur LaTeX sans jamais oser le demander (merci Woody Allen ), livre téléchargeable gratuitement ou en vente dans le commerce pour 15 €

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

Discussions similaires

  1. conversion nombre alphabet
    Par funfox dans le forum AS/400
    Réponses: 10
    Dernier message: 12/03/2009, 09h53
  2. Conversion nombre en date
    Par onyouma dans le forum Access
    Réponses: 6
    Dernier message: 30/01/2006, 11h06
  3. conversion nombre binaire -> decimal
    Par spoun95 dans le forum Langage
    Réponses: 7
    Dernier message: 25/11/2005, 17h46
  4. Conversion nombre<->caractere
    Par Mr Hyde dans le forum Langage
    Réponses: 3
    Dernier message: 21/09/2005, 01h27
  5. Conversion Nombre -> Texte
    Par Isis dans le forum Assembleur
    Réponses: 7
    Dernier message: 04/06/2003, 21h47

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