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

OpenOffice & LibreOffice Discussion :

calc code suppression colonnes non adjacentes [LibreOffice][Tableur]


Sujet :

OpenOffice & LibreOffice

  1. #1
    Membre à l'essai
    Homme Profil pro
    fonctionnaire utilisant VBA
    Inscrit en
    Août 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : fonctionnaire utilisant VBA
    Secteur : Service public

    Informations forums :
    Inscription : Août 2012
    Messages : 21
    Points : 13
    Points
    13
    Par défaut calc code suppression colonnes non adjacentes
    Bonjour,

    Je viens de passer sur LibreOffice et je souhaiterais faire une macro me permettant de supprimer plusieurs colonnes non adjacentes dans un tableau (Cf. Pièce jointe ou j'ai simplifié : 3 colonnes sur fond jaune à supprimer). J'ai essayé le code ci-après mais cela ne fonctionne pas (j'ai un problème avec la syntaxe de la zone à retenir et avec celle concernant la suppression en elle-même).

    sub Suppr_col

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim monDocument As Object, maTable As Object
    Dim lesColonnes As Object
    monDocument = ThisComponent
    maTable = monDocument.TextTables.getByName("H,N,P")
    lesColonnes = maTable.Columns
     
    lesColonnes.removeByIndex(1,3)' supprimer ces trois colonnes
     
    end sub

    Quelqu'un pourrait-il m'aider ?

    Par avance merci
    Fichiers attachés Fichiers attachés

  2. #2
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 222
    Points
    58 222
    Billets dans le blog
    11
    Par défaut
    Bonjour,

    Voici comment supprimer 3 colonnes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub SupprColonnes()
        Dim monDocument As Object, lesFeuilles As Object, maFeuillee As Object
        Dim lesSep As Variant, lesColonnes As Object
     
        monDocument = ThisComponent
        lesFeuilles = monDocument.Sheets
        maFeuille = lesFeuilles.getByName("Feuille1")
        lesColonnes = maFeuille.Columns
        lesColonnes.removeByIndex(1,3) ' supprimer trois colonnes
    End Sub
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  3. #3
    Membre à l'essai
    Homme Profil pro
    fonctionnaire utilisant VBA
    Inscrit en
    Août 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : fonctionnaire utilisant VBA
    Secteur : Service public

    Informations forums :
    Inscription : Août 2012
    Messages : 21
    Points : 13
    Points
    13
    Par défaut
    Bonsoir et merci.

    Cela ne répond pas précisément à mon problème qui est de supprimer les colonnes non adjacentes : H, N et P de la feuille "Destination" (Cf.Mon tableau joint).

    Bonne soirée

  4. #4
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 222
    Points
    58 222
    Billets dans le blog
    11
    Par défaut
    Euh... il suffit de modifier et de répéter la ligne suivante lesColonnes.removeByIndex(1,3).
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  5. #5
    Membre à l'essai
    Homme Profil pro
    fonctionnaire utilisant VBA
    Inscrit en
    Août 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : fonctionnaire utilisant VBA
    Secteur : Service public

    Informations forums :
    Inscription : Août 2012
    Messages : 21
    Points : 13
    Points
    13
    Par défaut
    Pouvez-vous préciser au regard de mon problème ?

    Par avance merci

    Bonne soirée

  6. #6
    Expert éminent
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    3 957
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 3 957
    Points : 9 297
    Points
    9 297
    Par défaut
    hello,
    un truc du genre :
    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
    sub Suppr_col
     
       Dim monDocument As Object, lesFeuilles As Object, maFeuillee As Object
        Dim lesSep As Variant, lesColonnes As Object
        monDocument = ThisComponent
        lesFeuilles = monDocument.Sheets
        maFeuille = lesFeuilles.getByName("Destination")
        lesColonnes = maFeuille.Columns
        IndexColumn =  maFeuille.getCellRangeByName("P1").getRangeAddress().StartColumn
        lesColonnes.removeByIndex(IndexColumn,1) ' supprimer  Colonne P
        IndexColumn =  maFeuille.getCellRangeByName("N1").getRangeAddress().StartColumn
        lesColonnes.removeByIndex(IndexColumn,1) ' supprimer  Colonne N
        IndexColumn =  maFeuille.getCellRangeByName("H1").getRangeAddress().StartColumn
        lesColonnes.removeByIndex(IndexColumn,1) ' supprimer  Colonne H     
    end sub
    devrait faire l'affaire. Il faut supprimer les colonnes de la droite vers gauche, sinon il y aura décalage dans les colonnes : si on supprime la colonne H en premier la colonne N devient M, la colonne P devient O.

    Ami calmant, J.P
    Jurassic computer : Sinclair ZX81 - Zilog Z80A à 3,25 MHz - RAM 1 Ko - ROM 8 Ko

  7. #7
    Membre à l'essai
    Homme Profil pro
    fonctionnaire utilisant VBA
    Inscrit en
    Août 2012
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : fonctionnaire utilisant VBA
    Secteur : Service public

    Informations forums :
    Inscription : Août 2012
    Messages : 21
    Points : 13
    Points
    13
    Par défaut
    Bonjour et surtout un grand merci. Cela fonctionne. Mon problème est résolu. C'est vrai qu'il faut penser au décalage des colonnes.

    Je vous souhaite une belle journée

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

Discussions similaires

  1. [XL-2003] boucle sur colonnes non adjacentes
    Par mlrdeni dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 01/01/2014, 11h35
  2. [PPT-2007] Sélection de plusieurs colonnes non adjacentes
    Par alers dans le forum Powerpoint
    Réponses: 0
    Dernier message: 29/03/2013, 12h39
  3. Réponses: 1
    Dernier message: 29/12/2005, 18h04
  4. [C#] GridView suppression colonne code behind
    Par damn dans le forum ASP.NET
    Réponses: 2
    Dernier message: 31/10/2005, 12h33
  5. Réponses: 1
    Dernier message: 28/09/2005, 18h10

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