Bonsoir Eric
Dans votre fichier
1- la seule plage qui doit être marquée comme une plage de filtre, est celle qui en est une
: pCrit1
Je ne peux pas vous dire si ça peut poser problème (je ne sais plus... je ne me suis pas
posé la question récemment !)
2- Ensuite vous avez créé une colonne de contrôle, vous ne la voulez pas dans votre
résultat : il ne faut donc pas la sélectionner quand vous appliquez votre filtre, encore
moins l'ajouter dans vos critères
3- Enfin, dans votre colonne de contrôle, vous avez testé votre critère sans utiliser une
fonction qui avait besoin pour argument d'une référence de cellule (ce qui aurait été le
cas avec "estvide") => pourquoi n'avez vous pas utilisé ce contrôle, formulé ainsi, dans
votre filtre, c'est ce qu'il faut faire.
Comme je vous l'ai écrit précédemment, une cellule vide dans la plage de filtre, n'est PAS
un critère.
Bonus : pour indiquer l'emplacement "d'export" il suffit d'indiquer la référence de la 1ère
cellule en haut à gauche où seront placés les résultats du filtre (avec plus de lignes,
vous ne savez pas nécessairement, combien de lignes seront filtrées, donc vous ne
définissez pas la plage de résultat, uniquement la référence de la 1ère cellule ! donc pas
besoin de plage nommée, à priori !
Une autre remarque, comme je vous l'ai écrit précédemment, je vous confirme que vous pouvez
obtenir le résultat avec un filtre standard et non un filtre spécial. La mise en oeuvre et
plus simple et rapide :
Sélectionner la zone à filtrer (sans sélectionner votre colonne de test donc, puisque vous
ne la voulez pas pour finir !)
Données, filtre standard,
choisissez votre colonnev(Te) et en valeur "non vide". pour les options du filtre (copier
les résultats vers et décocher conserver les critères de filtre), c'est comme pour le
filtre spécial.
Ainsi, si vous n'avez pas d'autres critères à définir, le fitlre standard suffit. Si vous
avez d'autres critères à définir (éventuellement avec des ET = même ligne, des OU=même
colonne), le fitlre spécial s'y prête, sinon, c'est superflu.
Donc
1 => modifiez les références de votre plage nommée pCrit1 pour enlever au moins la colonne O
2 => insérez votre critère en N3 soit <>""
3 => sélectionnez votre plage à filtrer B2 à F8 (et G8)
4=> Données / Filtre spécial
Et la suite... je crois que c'est bon.
Bonus 2 : si la taille de votre plage source est fixe, votre plage nommée est valable,
sinon, en respectant la règle suivante, vous aurez une sélection automatique, en plaçant le
curseur dans la zone
aucune ligne ou colonne adjacentre remplie autour d'une plage de valeurs qui n'a pas
d'intérêt pour le calcul (votre ligne 1 surtout, et la colonne G si vous la conservez, sont
à déplacer...
Bravo, l'étape suivante c'est les tableaux croisés ? ;-)
Claire
Le 2024-09-02 15:55, Isa&ric a écrit :
Merci Claire,
Il me semble bien maintenant avoir des plages de défini :
Filtre.jpg : https://www.cjoint.com/c/NIcnXKsxmRp <https://www.cjoint.com/c/NIcnXKsxmRp>
Test-plageImport (filtre spéciaux-3).ods
https://www.cjoint.com/c/NIcn1m2QYap <https://www.cjoint.com/c/NIcn1m2QYap>
Cela donne toujours une colonne en trop.
Éric
Le 02/09/2024 à 13:55, Ocleyr2lalune a écrit :
Pour simplifier la mise en place du filtre spécial
Nommer la zone destinée à être votre filtre spécial puis dans "gérer les plages nommées"
sélectionner filtre spécial dans les propriétés de la plage nommée
Ensuite pour appliquer votre filtre
Lire les critères dans... Dans le menu déroulant vous pourrez sélectionner votre plage de
filtre spécial.
A lire votre capture (très rapidement, je dis peut-être une betise) j'ai l'impression que
votre critère n'est pas là où vous dîtes qu'il est.
Le critère c'est colonne x non vide
Veillez bien à ce que vos 2 plages ne puissent se superposer. Par exemple vos critères
peuvent être sur une autre feuille ou sur les premières lignes de la feuille où vous
préférez placerez vos résultats.
Il est possible aussi que le filtre standard vous suffise si votre seul critère est telle
colonne non vide.
Pour exprimer le non vide dans un filtre spécial il ne suffit pas de laisser la cellule
non remplie (car ça signifie pas de filtre pour cette colonne...) mais je ne sais plus
comment je fais dans ce cas. Au besoin j'irais voir mes fichiers perso.
Si vous coincez toujours, prévenez nous.
Claire
Le 2 sept. 2024, à 10:17, Isa&ric <isaric.co <mailto:<a>@free.fr target=_blank>isaric.co
<http://isaric.co>@free.fr> a écrit:
Merci Claire.
J'arrive à faire un "Filtre spécial..."
Calc Filtre spécial.png:https://www.cjoint.com/c/NIcid4VQejp
<https://www.cjoint.com/c/NIcid4VQejp>
lorsque mon critère "Lire les critères de filtre dans" est
$'1-Plage'.$H$2:$H$3
avec en $'1-Plage'.$H$3 par exemple =j-001
Je voudrai que le critère soit ($'1-Plage'.$H$3) pour toutes les
"cellules non vide", est-ce possible ?
Éric
Le 01/09/2024 à 22:34, Ocleyr2lalune a écrit :
Bonjour Eric (je n'ai pas vu votre fichier, mais) le besoin
que vous évoquez, fait penser au filtre spécial (où vous
pouvez ajuster vos conditions, les faire varier par une
formule) ou même simplement le filtre standard, avez vous
essayé ? (pour le filtre standard il faut cocher dans les
options, "copier les résultats vers...", voir supprimer le
lien entre le résultat et la table filtrée)
https://help.libreoffice.org/latest/fr/text/scalc/01/12040201.html?&DbPAR=CALC
<https://help.libreoffice.org/latest/fr/text/scalc/01/12040201.html?&DbPAR=CALC>
https://help.libreoffice.org/latest/fr/text/scalc/guide/specialfilter.html?DbPAR=CALC
Claire Le 2024-09-01 18:58, Isa&ric a écrit :
Bonjour, Dans le fichier exemple Test-plageImport.ods (
https://www.cjoint.com/c/NIbqZ5uSinp ) qui comporte 3
onglets je souhaite importer une plage de données par
exemple A2:F7 de la feuille « 1-Plage » contenant les
cellules à importer vers la feuille « 2-Import » sous
condition que la cellule de la colonne « F »
correspondante à la ligne analysées, ne soit pas vide. Et
obtenir un résultat comme celui de la feuille « 3-Sup L
vide » où la ligne 3 de la feuille « 1-Plage » n’apparaît
pas et la ligne 4 vient alors se placer après/derrière la
ligne 2… D’avance merci pour vos aides ! Éric