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

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث

تعيد الدّالة 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

انظر أيضًا

مصادر