الفرق بين المراجعتين ل"Python/itertools/filterfalse"
(إضافة الصّفحة) |
|||
سطر 2: | سطر 2: | ||
تعيد الدّالة <code>itertools.filterfalse()</code> مُكرّرًا يُرشّح عناصر الكائن القابل للتّكرار المُعطى مُعيدًا تلك فقط التي تُعيد لها العبارة المنطقيّة المُعطاة القيمة المنطقيّة <code>False</code>. | تعيد الدّالة <code>itertools.filterfalse()</code> مُكرّرًا يُرشّح عناصر الكائن القابل للتّكرار المُعطى مُعيدًا تلك فقط التي تُعيد لها العبارة المنطقيّة المُعطاة القيمة المنطقيّة <code>False</code>. | ||
− | هذه الدّالة تعمل بطريقة مُعاكسة للدّالة <code>filter()</code>. | + | هذه الدّالة تعمل بطريقة مُعاكسة للدّالة <code>[[Python/filter|filter()]]</code>. |
== البنية العامة == | == البنية العامة == | ||
سطر 13: | سطر 13: | ||
العبارة المنطقيّة (تكون عادة دالّة) تُحدّد ما إذا كان العنصر سيُعاد أو لا. | العبارة المنطقيّة (تكون عادة دالّة) تُحدّد ما إذا كان العنصر سيُعاد أو لا. | ||
− | تُعاد العناصر فقط في حالة | + | تُعاد العناصر فقط في حالة أَعَادت لها العبارة المنطقيّة المُعطاة القيمةَ <code>False</code>. |
− | إن كانت قيمة هذا المُعامل تُساوي القيمة <code>None</code> فستُعاد العناصر التّي تُساوي قيمتها المنطقيّة القيمة <code>False</code>. | + | إن كانت قيمة هذا المُعامل تُساوي القيمة <code>None</code> فستُعاد العناصر التّي تُساوي [[Python/boolean|قيمتها المنطقيّة]] القيمة <code>False</code>. |
=== <code>iterable</code> === | === <code>iterable</code> === | ||
− | الكائن القابل للتّكرار المرغوب | + | الكائن القابل للتّكرار المرغوب ترشيح عناصره. |
== القيمة المعادة == | == القيمة المعادة == | ||
− | مُكرّر يحتوي على القيم التي أعادت لها | + | مُكرّر يحتوي على القيم التي أعادت لها العبارة المنطقيّة المُعطاة القيمةَ <code>False</code>. |
== أمثلة == | == أمثلة == | ||
− | المثال التّالي يوضّح كيفيّة عمل هذه الدّالة، نستعمل هنا تعبير lambda لترشيح عناصر قائمة، العناصر التي يُعيدها المكرّر | + | المثال التّالي يوضّح كيفيّة عمل هذه الدّالة، نستعمل هنا [[Python/lambda expressions|تعبير lambda]] لترشيح عناصر قائمة، العناصر التي يُعيدها المكرّر '''''ليست''''' أكبر من <code>10</code>: |
<syntaxhighlight lang="python3"> | <syntaxhighlight lang="python3"> | ||
>>> it = itertools.filterfalse(lambda x: x>10, [1, 4, 40, 5, 50, 65]) | >>> it = itertools.filterfalse(lambda x: x>10, [1, 4, 40, 5, 50, 65]) | ||
سطر 47: | سطر 47: | ||
* [[Python/filter|الدالة filter() في بايثون]]. | * [[Python/filter|الدالة filter() في بايثون]]. | ||
* [[Python/generators|المولدات Generators في بايثون]]. | * [[Python/generators|المولدات Generators في بايثون]]. | ||
+ | * [[Python/boolean|القيم المنطقيّة]]. | ||
+ | * [[Python/lambda expressions|تعبير lambda]]. | ||
== مصادر == | == مصادر == |
مراجعة 02:23، 10 يونيو 2018
تعيد الدّالة itertools.filterfalse()
مُكرّرًا يُرشّح عناصر الكائن القابل للتّكرار المُعطى مُعيدًا تلك فقط التي تُعيد لها العبارة المنطقيّة المُعطاة القيمة المنطقيّة False
.
هذه الدّالة تعمل بطريقة مُعاكسة للدّالة filter()
.
البنية العامة
itertools.filterfalse(predicate, iterable)
المعاملات
predicate
العبارة المنطقيّة (تكون عادة دالّة) تُحدّد ما إذا كان العنصر سيُعاد أو لا.
تُعاد العناصر فقط في حالة أَعَادت لها العبارة المنطقيّة المُعطاة القيمةَ False
.
إن كانت قيمة هذا المُعامل تُساوي القيمة None
فستُعاد العناصر التّي تُساوي قيمتها المنطقيّة القيمة False
.
iterable
الكائن القابل للتّكرار المرغوب ترشيح عناصره.
القيمة المعادة
مُكرّر يحتوي على القيم التي أعادت لها العبارة المنطقيّة المُعطاة القيمةَ False
.
أمثلة
المثال التّالي يوضّح كيفيّة عمل هذه الدّالة، نستعمل هنا تعبير lambda لترشيح عناصر قائمة، العناصر التي يُعيدها المكرّر ليست أكبر من 10
:
>>> it = itertools.filterfalse(lambda x: x>10, [1, 4, 40, 5, 50, 65])
>>> list(it)
[1, 4, 5]
ملاحظات
الدّالة مُكافئة لما يلي:
def filterfalse(predicate, iterable):
# filterfalse(lambda x: x%2, range(10)) --> 0 2 4 6 8
if predicate is None:
predicate = bool
for x in iterable:
if not predicate(x):
yield x
انظر أيضًا
- المكرِّرات Iterators في بايثون.
- الدالة filter() في بايثون.
- المولدات Generators في بايثون.
- القيم المنطقيّة.
- تعبير lambda.