[Résolu] Comment déplacer une colonne en plusieurs lignes ?

Discussions à propos du tableur Calc.
Les questions sur les macros doivent être postées dans la section dédiée en dessous.

Modérateur: Vilains modOOs

Règles du forum
Cette section est uniquement dédiée au tableur Calc. Vous ne devez pas poster ici de questions sur les macros mais utiliser la section éponyme.

[Résolu] Comment déplacer une colonne en plusieurs lignes ?

Messagepar tamcom » 13 Juin 2019 05:30

Bonjour à toutes et à tous,

J'ai écumé le net à la recherche d'une solution à mon problème, et malheureusement je n'arrive pas à le résoudre, donc je viens vous embêter un peu.

Voilà, j'utilise LibreOffice (version 6.0.5 il me semble), et j'ai un problème dans Calc. J'ai des données météorologiques (température) en colonnes, avec les mois et années en colonnes également. Je souhaite obtenir un tableau avec les années en ligne (mes années vont de 1901 à 2016 donc ça fait beaucoup de lignes...), les mois en colonne (12 colonnes), et les températures correspondantes.
Mon problème survient quand j'essaie de déplacer mes températures en lignes de 12 valeurs. Au début j'essayais de faire un tableau croisé dynamique, mais je ne veux pas faire de calculs sur mes valeurs, donc ça ne marchait pas. J'ai ensuite trouvé une fonction intéressante, la fonction DEPLACER, mais arrivé à la deuxième ligne, calc reprend les valeurs de la première ligne (de 1 à 12) au lieu de continuer avec le compte (de 12 à 23, etc). Le plus surprenant est qu'à la 11ème ligne, il recommence à me mettre des valeurs qui correspondent à la 317ème ligne. Bref je suis perdue.
Le code est le suivant:
Code : Tout sélectionner   AgrandirRéduire
=DECALER($A$2;((COLONNE()-3)+((LIGNE()-2)*12));0)

J'ai pourtant bien vérifié, (COLONNE()-3)+((LIGNE()-2)*12) me compte les lignes dans l'ordre, et revient à la ligne sans problèmes en continuant le compte.

Je vous mets mes données en pièce jointe si j'y arrive pour une meilleure compréhension.


Un grand merci à qui saura m'aider!!

Bonne soirée (il est minuit chez moi)!

La modération a écrit:Pour faciliter la lecture, formule mise entre balises par le modérateur.
Pièces jointes
Problème.ods
(33.54 Kio) Téléchargé 12 fois
OpenOffice 2.4 sous Windows XP
tamcom
Fraîchement OOthentifié
 
Message(s) : 1
Inscrit le : 12 Juin 2019 23:14

Re: Comment déplacer une colonne en plusieurs lignes?

Messagepar Michel JANZEF » 13 Juin 2019 07:56

Bonjour,
Si j'ai bien compris,
Pour les années et les 12 mois :
- Sélectionnez toutes vos données
- Copier
- Sélectionnez la cellule de destination
- Édition
- Collage spécial
- Cochez " Transposer "
En revanche, je n'ai pas compris à quoi correspondent les valeurs de la colonne A
Dernière édition par Michel JANZEF le 13 Juin 2019 11:08, édité 1 fois.
Domicile :
1- AOo 4.1.6 et LibO 6.1.6.3 (x64) - Windows 10 Famille 1803 64 bits
2- AOo 4.0.1 et LibO 4.1.5.3 sous Windows XP Familiale SP3
Bureau : LibO 5.1.2.2 (imposée) sous Linux Ubuntu 16.04
Avatar de l’utilisateur
Michel JANZEF
HédOOniste
HédOOniste
 
Message(s) : 1993
Inscrit le : 12 Jan 2006 11:04

Re: Comment déplacer une colonne en plusieurs lignes?

Messagepar micmac » 13 Juin 2019 08:44

Bonjour et bienvenue sur le forum,
Dans votre signature il y a écrit: OpenOffice 2.4 sous Windows XP
tamcom a écrit:j'utilise LibreOffice (version 6.0.5

C'est cette information qui devrait être indiquée dans votre signature accompagnée de la version exacte de l'OS.

Pour connaître la version que vous possédez : viewtopic.php?p=11582#p11582

Afin de profiter des dernières améliorations, il est fortement recommandé d'être à jour de la dernière version

Voici quelques exemples : LibO 6.1.6, sous Windows XP SP3, Vista SP2, Win7 SP1, Win 8.1, Win 10, Mac PPC 10.5.8, mac OS 10.14.5, Ubuntu 18.04 ...etc.

Accès direct à votre signature pour la corriger.

Cordialement.
Dans votre signature vous devez préciser la ou les versions exactes d'OpenOffice ou de LibreOffice et du ou des systèmes utilisés.
Exemple : AOO 4.1.6 (version imposée selon le cas) sous Win7 SP1, Win 8.1, Win 10, macOS 10.14.5, Ubuntu 18.10...
Avatar de l’utilisateur
micmac
RespOOnsable forum
RespOOnsable forum
 
Message(s) : 5895
Inscrit le : 28 Août 2010 09:45

Re: Comment déplacer une colonne en plusieurs lignes?

Messagepar Jeff » 13 Juin 2019 14:58

Bonjour et bienvenue,

Merci de suivre les recommandations du modérateur :wink:

tamcom a écrit:J'ai des données météorologiques (température) en colonnes, avec les mois et années en colonnes
Je vois bien les températures et les années... mais pas les mois :)

tamcom a écrit:=DECALER($A$2;((COLONNE()-3)+((LIGNE()-2)*12));0)
Cette formule, en colonne C, va chercher une valeur toutes les douze lignes, j'en déduis que pour le mois de Janvier, tu veux obtenir les températures en 1901, 1913, 1925, 1937 etc... ce qui semble être le cas dans ton fichier joint.

tamcom a écrit:Le plus surprenant est qu'à la 11ème ligne, il recommence à me mettre des valeurs qui correspondent à la 317ème ligne
Non reproduis sous ma configuration.
Si je prends la formule en C11 :
Code : Tout sélectionner   AgrandirRéduire
=DECALER($A$2;((COLONNE()-3)+((LIGNE()-2)*12));0)

Le décalage en ligne est donné par COLONNE()-3)+((LIGNE()-2)*12), ou bien COLONNE()-3)+((LIGNE(C11)-2)*12), qui renvoie 108.
On décale par rapport à A2 qui est déjà en ligne 2, donc on va chercher la ligne 110 (108 + 2).
Si je change le contenu de A110, cela actualise bien le résultat en C11.

Idem pour C12, ou le décalage en ligne est de (12-2) x 12 = 120 + les deux lignes de décalage 122, le contenu de A122 est celui reporté en C12.

Un tuto sur la fonction DECALER (et pas DEPLACER :mrgreen: ) :
viewtopic.php?f=29&t=42550

A +

 Ajout : Un tout petit peu plus long, une formule avec ADRESSE :
Code : Tout sélectionner   AgrandirRéduire
=ADRESSE(COLONNE()-3+((LIGNE()-1)*12);COLONNE($A1))

L’avantage étant de voir immédiatement les cellules visées :

AOO_forum.png
Cliquer sur l’image pour zoomer


Une fois que tu es sûr de la bonne formulation, il suffit d’englober le tout dans une fonction INDIRECT :

AOO_forum1.png
Cliquer sur l’image pour zoomer


Je préfère réserver l’usage de DECALER à la création de plages (d’où le but du tuto mentionné auparavant)

  
À lire avant tout !

Pour télécharger Apache OpenOffice

AOO 4.1.6 sur Debian Stable i586 10 (buster) et sur Win 10 pro x64
Jeff
GourOOu
GourOOu
 
Message(s) : 8077
Inscrit le : 18 Sep 2006 10:40
Localisation : France


Retour vers Tableur

Qui est en ligne ?

Utilisateur(s) parcourant ce forum : Aucun utilisateur inscrit et 8 invité(s)