1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2024-07-03 10:43:16 +00:00
TiddlyWiki5/editions/fr-FR/tiddlers/Introduction to Filters.tid

89 lines
4.7 KiB
Plaintext
Raw Normal View History

created: 20140410101941871
2015-06-21 09:44:58 +00:00
fr-title: Introduction à la rédaction d'un filtre
modified: 20150619210516062
tags: Learning Filters
title: Introduction to filters notation
type: nq
2015-06-21 09:44:58 +00:00
<<.preamble """Ceci décrit les bases de l'écriture d'un [[filtre|Filters]] de sélection d'un ensemble de tiddlers. Pour une présentation plus technique, voir [[Syntaxe d'un filtre|Filter Syntax]].""">>
2015-06-21 09:44:58 +00:00
<$macrocall $name=".tip" _="""Les filtres ne font rien par eux-même si vous vous contentez de les intégrer dans un tiddler. Il faut un contexte. Une manière facile d'expérimenter les filtres est de les saisir dans l'option <<.advancedsearch-tab Filter>> de l'onglet [[Recherche avancée|$:/AdvancedSearch]]."""/>
2015-06-21 09:44:58 +00:00
Le plus simple des cas se présente lorsque vous savez exactement quels tiddlers vous recherchez. Saisissez chaque titre entre une paire de double crochets, un espace entre chacun<<:>>
2015-06-21 09:44:58 +00:00
> `[[Livre de recettes]] [[OeufsBrouillés]] [[Gateau aux pommes de moman]]`
2015-06-21 09:44:58 +00:00
Vous pouvez omettre les crochets quand un titre ne contient aucun espace<<:>>
2015-06-21 09:44:58 +00:00
> `[[Livre de recettes]] OeufsBrouillés [[Gateau aux pommes de moman]]`
2015-06-21 09:44:58 +00:00
La paire de double crochets est une abréviation de<<:>>
2015-06-21 09:44:58 +00:00
> `[title[OeufsBrouillés]]`
2015-06-21 09:44:58 +00:00
... qui offre une syntaxe du <<.def "modèle général">> de tous les filtres<<:>>
2015-06-21 09:44:58 +00:00
> `[operateur[paramètre]]`
2015-06-21 09:44:58 +00:00
En l'occurence, voici comment sélectionner tous les tiddlers étiquetés <<.tag Recipe>><<:>>
2015-06-21 09:44:58 +00:00
> `[tag[Recette]]`
2015-06-21 09:44:58 +00:00
Vous pouvez inverser la sélection en ajoutant le point d'exclamation `!` juste avant l'opérateur. Par exemple, nous pouvons sélectionner tous les tiddlers <<.em sans>> l'étiquette <<.tag Recette>><<:>>
2015-06-21 09:44:58 +00:00
> `[!tag[Recette]]`
2015-06-21 09:44:58 +00:00
Les tiddlers peuvent être filtrés par d'autres champs que les titres ou les étiquettes<<:
>>
2015-06-21 09:44:58 +00:00
> `[field:convive[4]]`
2015-06-21 09:44:58 +00:00
Cette exemple sélectionnera tous les tiddlers qui ont <<.value 4>> dans leur champ <<.field convive>>.
2015-06-21 09:44:58 +00:00
Comme le mot "convive" n'est pas un opérateur filtre standard (et n'est pas près de le devenir), vous pouvez omettre le préfixe `field:` en toute sécurité<<:>>
2015-06-21 09:44:58 +00:00
> `[convive[4]]`
2015-06-21 09:44:58 +00:00
!Combinaisons
2015-06-21 09:44:58 +00:00
Les filtres que nous avons examinés jusqu'à présent ont chacun une étape. Mais vous pouvez <<.def exécuter>> plusieurs étapes ensemble comme ceci<<dp>>
2015-06-21 09:44:58 +00:00
> `[tag[Végétarien]!tag[soupe]convive[4]]`
2015-06-21 09:44:58 +00:00
Notez que la séquence entière est contenue dans une seule paire de crochets.
2015-06-21 09:44:58 +00:00
Un tiddler doit correspondre à <<.em toutes>> les étapes de la séquence. Ainsi l'exemple supra renvoie à toutes les recettes végétariennes (autre que soupes) pour 4 convives.
2015-06-21 09:44:58 +00:00
Une série de séquences séparée sélectionnera les tiddlers qui correspondent à l'<<.em une>> des séquences. Nous pouvons réutiliser ceci pour trouver les recettes pour 3, 4 or 5 convives<<:>>
2015-06-21 09:44:58 +00:00
> `[convive[3]] [convive[4]] [convive[5]]`
2015-06-21 09:44:58 +00:00
Si nous voulons ignorer les recettes végétariennes pour 4 convives, nous formulerons ainsi<<:>>
2015-06-21 09:44:58 +00:00
> `[convive[3]] [convive[4]!tag[Végétarien]] [convive[5]]`
2015-06-21 09:44:58 +00:00
Par défaut, chaque séquence prend en compte tous les tiddlers du wiki. Mais on peut utiliser le signe `+` pour ne tenir compte que des seuls tiddlers sélectionnés par les précédentes séquences<<:>>
2015-06-21 09:44:58 +00:00
> `[convive[3]] [convive[4]] [convive[5]] +[tag[Végétarien]] +[sort[titre]]`
2015-06-21 09:44:58 +00:00
Ceci sélectionne les recettes pour 3, 4 ou 5 convives, puis filtre <<.em celles>> qui correspondent uniquement aux végétariennes, et enfin trie ce qui reste dans l'ordre alphabétique des titres.
2015-06-21 09:44:58 +00:00
D'une façon similaire, nous pouvons utiliser le signe `-` pour <<.em extraire>> une séquence de tiddlers du résultat précédent. Ici nous sélectionnons toutes les recettes végétariennes exceptées deux<<:>>
2015-06-21 09:44:58 +00:00
> `[tag[Végétarien]] -[title[OeufsBrouillés]] -HaricotsSurToast`
2015-06-21 09:44:58 +00:00
!Paramètres spéciaux
2015-06-21 09:44:58 +00:00
Le paramètre de chaque étape que nous avons vu jusqu'à présent s'insérait entre crochets, signifiant un traitement littéral par ~TiddlyWiki. Mais deux autres formes de parenthèses sont possibles<<:>>
2015-06-21 09:44:58 +00:00
<<.def "Les accolades">> `{}` indiquent que le paramètre est une [[Référence textuelle|TextReference]], et que sa valeur doit être recherchée dans un tiddler spécial. Par exemple, si nous avons un tiddler nommé <<.tid Préférence>> dont le texte apparait être le mot <<.value Végétarien>>, nous pouvons dire
2015-06-21 09:44:58 +00:00
> `[tag{Préférence}]`
2015-06-21 09:44:58 +00:00
est une alternative à `[tag[Végétarien]]`. Ce qui permet à 'préférence' d'évoluer dans le temps.
2015-06-21 09:44:58 +00:00
<<.def "Les chevrons">> `<>` indiquent que le paramètre est le nom d'une [[variable|Variables]] dont la valeur sera utilisée en lieu et place. Ici, nous utilisons la variable intégrée <<.vlink currentTiddler>> au sein d'un filtre qui sélectionne tous les tiddlers dont le texte contient le titre du tiddler en cours<<:>>
2015-06-21 09:44:58 +00:00
> `[search<currentTiddler>]`