الدالة isinstance()‎ في بايثون

من موسوعة حسوب
مراجعة 12:12، 22 مايو 2018 بواسطة عبد اللطيف ايمش (نقاش | مساهمات) (استبدال النص - 'Python/class-definition' ب'Python/class_definition')

تعيد الدّالة isinstance()‎ قيمة منطقيّةً تُشير إلى ما إذا كان الكائن المُعطى نسخة (instance) من الصّنف المُعطى أم لا.

البنية العامة

isinstance(object, classinfo)

المعاملات

object

الكائن المرغوب التّحقّق من كونه نسخةً من الصّنف (أو النّوع) المُعطى.

classinfo

الصّنف أو النّوع المرغوب التّحقق من أنّ الكائن نسخة منه.

يُمكن كذلك أن يقبل صفًّا (أو عدّة صفوف) من الأصناف أو الأنواع للتحقّق من أنّ الكائن نُسخة من أحدها.

القيمة المعادة

  • القيمة True إن كان الكائن نُسخة من الصّنف أو نسخة من أحد الأصناف الفرعيّة (سواء كان مُباشرًا، أو غير مباشرٍ، أو وهميًّا). والقيمة False إن لم يكن كذلك.

الاستثناءات

  • يُطلق استثناء TypeError إن لم تكن قيمة المُعامل classinfo نوعًا أو صفّ أنواعٍ أو عدّة صفوف من هذه الصّفوف.

أمثلة

المثال التّالي يوضّح كيفيّة عمل هذه الدّالة:

>>> isinstance(1, int) # عدد صحيح نسخة من نوع الأعداد الصّحيحة
True
>>> isinstance(1.0, int) # العدد ليس صحيحًا بل عشري
False
>>> isinstance(1.0, (int, float))
True

>>> class A: # صنف
...     pass
... 
>>> class B(A): # صنف وارث
...     pass
... 
>>> a = B() # كائن من الصّنف الوارث
>>> isinstance(a, B) # الكائن نسخة من صنفه
True
>>> isinstance(a, A) # الكائن نسخة من الصّنف الأب لصنفه
True

انظر أيضًا

مصادر