الفرق بين المراجعتين لصفحة: «Python/boolean»

من موسوعة حسوب
لا ملخص تعديل
طلا ملخص تعديل
 
(مراجعة متوسطة واحدة بواسطة مستخدم واحد آخر غير معروضة)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE:القيم المنطقية في بايثون}}</noinclude>
<noinclude>{{DISPLAYTITLE:القيم المنطقية في بايثون}}</noinclude>
القيمتان المنطقيتان (البوليانيتان، Boolean) اللتان تدعمهما بايثون هما <code>True</code> و <code>False</code> وهما كائنان ثابتان (Constant objects) يعبران عن صحّة تعبير ما، فإمّا أن يكون صحيحًا True أو خطأً False. تعدّ القيم المنطقية نوعًا فرعيًا (subtype) من [[Python/int|الأعداد الصحيحة]]، وتسلك القيمتان <code>False</code> و <code>True</code> سلوك القيمتين <code>0</code> و <code>1</code> على التوالي في معظم السياقات تقريبًا، ويستثنى من ذلك تحويل القيم المنطقية إلى [[Python/str|سلاسل نصية]]، فتعاد حينئذ السلسلتان النصيتان <code>"False"</code> و <code>"True"</code> على التوالي.<syntaxhighlight lang="python3" line="1">
القيمتان المنطقيتان (البوليانيتان، Boolean) اللتان تدعمهما [[Python|بايثون]] هما <code>True</code> و <code>False</code> وهما كائنان ثابتان (Constant objects) يعبران عن صحّة تعبير ما، فإمّا أن يكون صحيحًا True أو خطأً False. تعدّ القيم المنطقية نوعًا فرعيًا (subtype) من [[Python/int|الأعداد الصحيحة]]، وتسلك القيمتان <code>False</code> و <code>True</code> سلوك القيمتين <code>0</code> و <code>1</code> على التوالي في معظم السياقات تقريبًا، ويستثنى من ذلك تحويل القيم المنطقية إلى [[Python/str|سلاسل نصية]]، فتعاد حينئذ السلسلتان النصيتان <code>"False"</code> و <code>"True"</code> على التوالي.<syntaxhighlight lang="python3" line="1">
>>> foo = True  
>>> foo = True  
>>> bar = False
>>> bar = False
سطر 7: سطر 7:


== اختبار القيمة الصحيحة ==
== اختبار القيمة الصحيحة ==
يمكن اختبار أي كائن لمعرفة القيمة الصحيحة وذلك لاستخدامه كشرط في عبارة <code>[[Python/if|if]]</code> أو <code>[[Python/while|while]]</code> أو كمعامل [[Python/bool-operations|للعوامل المنطقية]].
يمكن اختبار أي كائن لمعرفة القيمة الصحيحة وذلك لاستخدامه كشرط في عبارة <code>[[Python/if|if]]</code> أو <code>[[Python/while|while]]</code> أو كمعامل [[Python/bool_operations|للعوامل المنطقية]].


تعدّ بايثون الكائن صحيحًا بصورة افتراضية إلا إذا كان صنفه يعرّف التابع ‎<code>__bool__()‎</code> الذي يعيد القيمة <code>False</code> أو تابع <code>‎__len__()</code>‎‎ يعيد القيمة «صفر» عند استدعائه مع الكائن.
تعدّ بايثون الكائن صحيحًا بصورة افتراضية إلا إذا كان صنفه يعرّف التابع ‎<code>__bool__()‎</code> الذي يعيد القيمة <code>False</code> أو تابع <code>‎__len__()</code>‎‎ يعيد القيمة «صفر» عند استدعائه مع الكائن.
سطر 15: سطر 15:
* الصفر في أي نوع عددي: <code>0</code>، أو <code>0.0</code>، أو <code>‎Fraction(0,1)</code>‎، أو <code>Decimal(0)</code>‎، أو <code>0j</code>.
* الصفر في أي نوع عددي: <code>0</code>، أو <code>0.0</code>، أو <code>‎Fraction(0,1)</code>‎، أو <code>Decimal(0)</code>‎، أو <code>0j</code>.
* التسلسلات والمجموعات الفارغة: <code><nowiki>''</nowiki></code>، أو <code>()</code>، أو <code>[]</code>، أو <code>{}</code>، أو <code>range(0)</code>‎، أو <code>set()</code>‎.
* التسلسلات والمجموعات الفارغة: <code><nowiki>''</nowiki></code>، أو <code>()</code>، أو <code>[]</code>، أو <code>{}</code>، أو <code>range(0)</code>‎، أو <code>set()</code>‎.
تعيد العمليات والدوالّ الداخلية التي تمتلك نتائج منطقية (بوليانية) دائمًا القيمة <code>0</code> أو <code>False</code> للخطأ، وتعيد <code>1</code> أو <code>True</code> للقيم الصحيحة، إلا إذا صُرّح بغير ذلك (باستثناء [[Python/bool-operations|العمليتان المنطقيتان]] <code>or</code> و <code>and</code> اللتان تعيدان دائمًا واحدًا من عواملهما فقط، وتعرف هذه الحالة بالدارة القصيرة short-circuit. للمزيد من المعلومات راجع [[Python/bool-operations|العمليات المنطقية]]).
تعيد العمليات والدوالّ الداخلية التي تمتلك نتائج منطقية (بوليانية) دائمًا القيمة <code>0</code> أو <code>False</code> للخطأ، وتعيد <code>1</code> أو <code>True</code> للقيم الصحيحة، إلا إذا صُرّح بغير ذلك (باستثناء [[Python/bool_operations|العمليتان المنطقيتان]] <code>or</code> و <code>and</code> اللتان تعيدان دائمًا واحدًا من عواملهما فقط، وتعرف هذه الحالة بالدارة القصيرة short-circuit. للمزيد من المعلومات راجع [[Python/bool_operations|العمليات المنطقية]]).


يمكن استخدام الدالة الداخلية <code>[[Python/bool|bool()]]‎</code> لتحويل أي قيمة إلى قيمة منطقية إذا كان بالإمكان التحقق من صحّة القيمة كما ورد في أعلاه.
يمكن استخدام الدالة الداخلية <code>[[Python/bool|bool()]]‎</code> لتحويل أي قيمة إلى قيمة منطقية إذا كان بالإمكان التحقق من صحّة القيمة كما ورد في أعلاه.

المراجعة الحالية بتاريخ 09:11، 7 أكتوبر 2022

القيمتان المنطقيتان (البوليانيتان، Boolean) اللتان تدعمهما بايثون هما True و False وهما كائنان ثابتان (Constant objects) يعبران عن صحّة تعبير ما، فإمّا أن يكون صحيحًا True أو خطأً False. تعدّ القيم المنطقية نوعًا فرعيًا (subtype) من الأعداد الصحيحة، وتسلك القيمتان False و True سلوك القيمتين 0 و 1 على التوالي في معظم السياقات تقريبًا، ويستثنى من ذلك تحويل القيم المنطقية إلى سلاسل نصية، فتعاد حينئذ السلسلتان النصيتان "False" و "True" على التوالي.

>>> foo = True 
>>> bar = False

اختبار القيمة الصحيحة

يمكن اختبار أي كائن لمعرفة القيمة الصحيحة وذلك لاستخدامه كشرط في عبارة if أو while أو كمعامل للعوامل المنطقية.

تعدّ بايثون الكائن صحيحًا بصورة افتراضية إلا إذا كان صنفه يعرّف التابع ‎__bool__()‎ الذي يعيد القيمة False أو تابع ‎__len__()‎‎ يعيد القيمة «صفر» عند استدعائه مع الكائن.

فيما يلي قائمة بالكائنات الداخلية التي تعدّها اللغة False:

  • الثوابت المعرّفة على أنّها خطأ: وهي None و False.
  • الصفر في أي نوع عددي: 0، أو 0.0، أو ‎Fraction(0,1)‎، أو Decimal(0)‎، أو 0j.
  • التسلسلات والمجموعات الفارغة: ''، أو ()، أو []، أو {}، أو range(0)‎، أو set()‎.

تعيد العمليات والدوالّ الداخلية التي تمتلك نتائج منطقية (بوليانية) دائمًا القيمة 0 أو False للخطأ، وتعيد 1 أو True للقيم الصحيحة، إلا إذا صُرّح بغير ذلك (باستثناء العمليتان المنطقيتان or و and اللتان تعيدان دائمًا واحدًا من عواملهما فقط، وتعرف هذه الحالة بالدارة القصيرة short-circuit. للمزيد من المعلومات راجع العمليات المنطقية).

يمكن استخدام الدالة الداخلية bool() لتحويل أي قيمة إلى قيمة منطقية إذا كان بالإمكان التحقق من صحّة القيمة كما ورد في أعلاه.

أمثلة

أمثلة نموجية عمّا تعدّة لغة بايثون على أنه True، وما تعدّه على أنَّه False:

>>> bool(2)
True
>>> bool("Python")
True
>>> bool(0)
False
>>> bool()
False
>>> bool(None)
False

انظر أيضًا

مصادر