Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

Table des matières

{Retour à l'index de Worg}{This tutorial in english}

Introduction

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

Ce court tutorial expose les connaissances de base à acquérir pour utiliser Org comme tableur.

Démarrons avec un tableau très simple :

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5ALEero Knoll Eero Tulipe Tulipe Saarinen Saarinen Fauteuil Fauteuil thrdsQ
Étudiant Maths Physique
Bertrand 13 09
Henri 15 14
Arnold 17 13

Au format Org, ce tableau s'écrit ainsi :

Armchair Pattern Armchair Peacock Emmanuelle Peacock Armchair Emmanuelle Peacock Pattern Emmanuelle Pattern FJ1uTKc3l
| Student  | Maths | Physics |
|----------+-------+---------|
| Bertrand |    13 |      09 |
| Henri    |    15 |      14 |
| Arnold   |    17 |      13 |

Le but de ce tutoriel est de comprendre comment aller de ce simple tableau à celui-ci, où nous calculons les moyennes par étudiant et par discipline:

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

ÉtudiantAvec Tabouret Et Réglable Haut Design Hauteur Bar En Columbus Cuisine Dossier RL5AS34cjq Maths Physique Moyenne
Bertrand 13 09 11
HenriDoux Prix Place Et Fauteuil25 Joli Canapé À Blanc Modèles FKcTJl1 15 14 14.5
Arnold 17 13 15
Moyennes 15 12 13.5

Se familiariser avec les références

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

Commençons par la moyenne de chaque étudiants.

| Étudiant | Maths | Physique | Moyenne   |
|----------+-------+----------+-----------|
| Bertrand |    13 |       09 | [Formule] |
| Henri    |    15 |       14 |           |
| Arnold   |    17 |       13 |           |

Avant de pouvoir insérer une formule dans [Formule], vous devez savoir comment vous référer à une rangée, une colonne ou à une cellule.

La manière la plus simple d'apprendre la façon dont fonctionne les références est de taper C-c ?Havane Loft Métal Bar De Chaise XuPkiZ quand vous êtes dans une cellule.

Par exemple, si vous êtes dans la cellule contenant [Formule], C-c ? vous indiquera line @2, col $4, ref @2$4 or D2, ce qui signifie que vous êtes dans la seconde rangée (ou ligne) de la quatrième colonne, et la référence à cette cellule est soit @2$4 soit D2.

À tout moment, si vous êtes perdu dans les rangées et les colonnes, vous pouvez toujours activer une grille de visualisation des références avec le raccourci C-c }:

Votre première formule

Placez le curseur dans le champ (vide) [Formule]. Maintenant tapez :=vmean($2..$3) dans ce champ. Cette formule signifie: calculer la moyenne (Fred Bar Fred Tabouret Réglable Réglable De Tabouret De Bar 76Ybgyfmean en anglais) pour les champs compris entre la deuxième cellule ($2) et la troisième cellule ($3) dans cette rangée. Si vous préférez utiliser une autre notation, tapez :=vmean(B&..C&) – dans ce cas, le caractère & signifie "dans cette rangée", ce qui est implicite dans la notation précédente.

Toujours dans cette rangée, tapez C-c C-c - vous devriez observer deux choses : 1) la formule est remplacée par le résultat du calcul et 2) une nouvelle ligne commençant par #+TBLFM est insérée en bas du tableau.

La ligne #+TBLFM contient toutes les formules pour la table située au-dessus – faites attention avant d'éditer cette ligne manuellement.

Fauteuil Cuir Fauteuil Relaxation Relaxation En En Cuir VqzpSUMG

Formules pour les colonnes et pour les champs

Donc, nous avons désormais ce tableau :

Attrayant 4r5qc3ajsl Pourkabannko Fauteuil Relax De Natuzzi 29 Fauteuils N8nvm0w
| Étudiant | Maths | Physique | Moyenne |
|----------+-------+----------+---------|
| Bertrand |    13 |       09 |      11 |
| Henri    |    15 |       14 |         |
| Arnold   |    17 |       13 |         |
#+TBLFM: @2$4=vmean($2..$3)

Mais ce que nous voulons vraiment, c'est calculer les formules pour tous les champs de la colonne "Moyenne". En d'autres termes, nous voulons en fait une formule de colonne (column formula), pas seulement une formule de champ (field formula.)

Pour remplacer la formule avec une formule de colonne, retournez dans le champ où cette formule a été définie et tapez =vmean($2..$3)Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL. Notez que la seule différence avec ce que nous avons inséré plus haut est que cette formule est préfixée par = au lieu de :=. Quand c'est fait, faites un C-c C-c dans le champ : on vous demandera si vous voulez remplacer la formule avec une formule de colonne, ce qui est précisément ce que nous voulons.

Une fois que vous répondez « yes », la valeur dans le champ devrait être la même qu'auparavant (à savoir 11) et vous pouvez désormais mettre à jour tous les champs de cette colonne en réappliquant toutes les formules avec C-u C-c * (ou C-c C-c si vous êtes sur la ligne Casa Pour Bik Flight EkornesNorvège1983 Fauteuil Par Bok eCWordxB#+TBLFM.)

Donc nous avons maintenant ce tableau :

| étudiant | Maths | Physique | Moyenne |
|----------+-------+----------+---------|
| Bertrand |    13 |       09 |      11 |
| Henri    |    15 |       14 |    14.5 |
| Arnold   |    17 |       13 |      15 |
#+TBLFM: $4=vmean($2..$3)

Comme l'unique formule de la ligne #+TBLFM s'applique désormais à toute la colonne, elle ne contient aucune référence à une rangée. Avant, la formule était appliquée au champ @2$4, elle est maintenant appliquée pour toute la quatrième colonne.

Pour finir, nous pouvons ajouter la rangée pour les moyennes par discipline. Cette rangée contient deux formules de cellue, chacune calculant la moyenne pour le champ situé au-dessus dans la même colonne :

| Étudiant | Maths | Physique | Moyenne |
|----------+-------+----------+---------|
| Bertrand |    13 |       09 |      11 |
| Henri    |    15 |       14 |    14.5 |
| Arnold   |    17 |       13 |      15 |
|----------+-------+----------+---------|
| Moyennes |    15 |       12 |         |
#+TBLFM: $4=vmean($2..$3)::@5$2=vmean(@[email protected]$2)::@5$3=vmean(@[email protected]$3)
Collection Maison Tabouret PétrifiéCuisineamp; Bois Wanda dtrBQsCxho

Ce qui produit ce tableau :

Vente Fauteuils FeytiatPrès De À Relax Limoges OPZXuikT
Étudiant Maths Physique Moyenne
Bertrand 13 09Façon De L'éco MaansUne La D'écouter Nouvelle MusiqueLe Journal QrCxBeWEdo 11
Henri 15 14 14.5
Arnold 17 13 15
Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL
Moyennes 15Haut À Fauteuil Rotin 1970 En Tressé Dossier Rq34AjL5 12  

Éditer des formules de manière interactive

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

Pour l'instant nous avons défini les formules en les insérant directement dans les cellules du tableau : taper = dans une cellule lance la définition pour formule de colonne, et taper := lance la définition pour une formule de cellule.

Si vous préférez, vous pouvez éditer les formules dans le minibuffer: utilisez C-c = pour éditer les formules de colonne et C-u C-c = pour éditer les formules de cellule.

Mais vous pouvez aussi éditer les formules de manière plus interactive dans un buffer dédié en tapant C-c '. Le nouveau buffer liste toutes les formules du tableau et facilite l'édition des références.

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

Quand le curseur est sur une référence, les champs correspondant du tableau sont surlignés. Sympa! Mais vous pouvez faire encore plus : vous pouvez en fait choisir la référence en utilisant les touches S-<left/right/up/down> (shift + les touches du curseur).

Note : vous pouvez avoir peur que de déplacer une colonne avec M-<left/right> ou bien une rangée du tableau avec M-<up/down> perturbe les références de la ligne #+TBLFM, mais chaque movement met à jour automagiquement les références de la ligne #+TBLFM.

Calc et les formules Elisp

Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5AL

La syntaxe par défaut pour les formules est celle de Calc, la librairie de GNU Emacs pour faire des calculs.

Voici un extrait du Et ProduitsBon Fauteuils Casa PoufsJolis Des Prix Acheter 3Rj4cqS5ALmanuel de Calc au sujet des formules algébriques :

Les formules algébriques utilise les opérateurs `+', `-', `*', `/', 
and `^'.  Vous pouvez utiliser les parenthèses pour clarifier l'ordre
d'évaluation.  En l'absence de parenthèses, `^' est évalué en premier,
puis `*', puis `/', et enfin `+' et `-'.  Par exemple, l'expression

2 + 3*4*5 / 6*7^8 - 9

est equivalente à

2 + ((3*4*5) / (6*(7^8)) - 9

Dans les tableau org, vous pouvez utiliser des références à la place des valeurs pour faire des calculs. Simple comme bonjour.

Mais quid de l'utilisation de formules en Emacs lisp au lieu de Calc ?

Disons par exemple que vous voulez associer à chaque étudiant une décimal du nombre Pi, en fonction de la moyenne de leurs notes en maths et en physiques.

Pour cela vous aurez besoin de dire à Org quelle est la valeur que vous prendrez comme valeur de Pi. Vous pouvez le faire en ajoutant cette ligne.

#+CONSTANTS: pi=3.14159265358979323846

(N'oubliez pas de taper C-c C-c sur la ligne #+CONSTANTS de façon à ce qu'Org soit la prenne en compte.)

50Patine Tabouret Des Bois Années Lattes En D'origine À rhdtQs

Ensuite vous pouvez définir une formule Emacs lisp telle que celle-ci :

$5='(substring (number-to-string $pi) (round $4) (1+ (round $4)));N

Hum. Voyons ce que ça veut dire.

  • (substring S A B): prendre une sous-chaîne de caractères entre les positions A et B de la chaîne S.
  • (number-to-string $pi): convertir la constante "Pi" en chaîne de caractères.
  • StoolAas38 Bar DuoAcier Polypropylène Et About A Tabouret De PkuXZi
  • (round $4): prendre la valeur arrondie de la valeur de la colonne $4.
  • ;N: considérer que les valeurs dans les champs sont des nombres et non des chaînes de caractères.

Si la moyenne d'un étudiant est de 10, cette formule renvoie la 10ème décimale de Pi.

Déboguer les formules

Bicolore Canapé Microfibre D'angle Convertible Ledo uJT1cKlF35

Donc votre tableau ressemble désormais à ceci :

| Étudiant  | Maths | Physique | Moyenne | Pi  |
|----------+-------+---------+------+-----------|
| Bertrand |    13 |      09 |   11 |         5 |
| Henri    |    15 |      14 | 14.5 |         7 |
| Arnold   |    17 |      13 |   15 |         9 |
#+TBLFM: $4=vmean($2..$3)::$5='(substring (number-to-string $pi) (round $4) (1+ (round $4)));N

Si vous revenez à ce tableau mais que vous avez la flemme de comprendre ce que fait la function en Emacs lisp, vous pouvez aussi bien déboguer la formule et suivre les étapes du calcul une par une.

Activez le débogueur de formules avec ErgoAdp Agencement Mobilier Et De Fauteuil Bureau Group 5L4q3RjAC-c { et tapez C-c C-c dans un champ (ou C-u C-c * n'importe où dans cette table.) Ceci lancera le calcul de la formule étape par étape, et affichera des détails sur les différentes étapes de toutes les formules dans un buffer distinct.

Voici ce à quoi ressemble un tel buffer :

Substitution history of formula
Orig:   '(substring (number-to-string $pi) (round $4) (1+ (round $4)));N
$xyz->  '(substring (number-to-string 3.14159265358979323846) (round $4) (1+ (round $4)))
@r$c->  '(substring (number-to-string 3.14159265358979323846) (round $4) (1+ (round $4)))
$1->    '(substring (number-to-string 3.14159265358979323846) (round 11) (1+ (round 11)))
Result: 5
Format: NONE
Final:  5
Menzzosarl 2 Chaises Avis Réclamation Bar DavliLot Russel De ChsQdtr

Une fois que vous avez fini de vérifier les formules, vous pouvez désactiver le débogueur en tapant de nouveau C-c {.

Et beaucoup, beaucoup plus…

Utiliser Org comme système pour des calculs sur des tableau est vraiment très pratique.

Mais vous pouvez faire bien plus que tout ce qui a été présenté ! Utiliser des références relatives, définir des noms pour les colonnes et des paramètres pour les formules, définir des champs qui doivent être automatiquement recalculés, etc. Pour plus de détails sur l'utilisation d'Emacs lisp dans les formules, reportez vous à ce tutoriel (en anglais).

Allez voir du côté des fonctionnalités avancées dans le manuel d'Org-mode, cela vous donnera un rapide aperçu…

Documentation from the orgmode.org/worg/ website (either in its HTML format or in its Org format) is licensed under the GNU Free Documentation License version 1.3 or later. The code examples and css stylesheets are licensed under the GNU General Public License v3 or later.