الفرق بين المراجعتين لصفحة: «Python/isinstance»
< Python
إضافة الصّفحة |
|||
سطر 14: | سطر 14: | ||
الصّنف أو النّوع المرغوب التّحقق من أنّ الكائن نسخة منه. | الصّنف أو النّوع المرغوب التّحقق من أنّ الكائن نسخة منه. | ||
يُمكن كذلك أن يقبل صفًّا (أو عدّة صفوف) من الأصناف أو الأنواع للتحقّق من أنّ الكائن نُسخة من أحدها. | يُمكن كذلك أن يقبل صفًّا (أو عدّة صفوف) من الأصناف أو الأنواع للتحقّق من أنّ الكائن نُسخة من أحدها. | ||
== القيمة المعادة == | == القيمة المعادة == |
مراجعة 19:24، 4 مايو 2018
تعيد الدّالة 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