الثوابت في بايثون

من موسوعة حسوب

تقدم بايثون مجموعة من الثوابت، بعضها في مجال الأسماء الداخلي، أما البعض الآخر فيضاف من قبل الوحدة site إلى مفسّر بايثون التفاعلي.

ثوابت في مجال الأسماء الداخلي

False

يمثّل هذا الثابت القيمة الخاطئة للنوع bool. لا تسمح اللغة بإسناد أي قيمة إلى هذا الثابت وستطلق الخطأ SyntaxError عند محاولة القيام بذلك.

True

يمثّل هذا الثابت القيمة الصحيحة للنوع bool. لا تسمح اللغة بإسناد أي قيمة إلى هذا الثابت وستطلق الخطأ SyntaxError عند محاولة القيام بذلك.

None

هذا الثابت هو القيمة الوحيدة للنوع NoneType، ويستخدم None للتعبير عن غياب القيمة، كما في حالة عدم تمرير الوسائط الافتراضية إلى الدالة. لا تسمح اللغة بإسناد أي قيمة إلى هذا الثابت وستطلق الاستثناء SyntaxError عند محاولة القيام بذلك.

NotImplemented

هذا الثابت هو قيمة خاصة يجب أن تعيدها التوابع الخاصة بالنظام الثنائي (binary) مثل: ‎__eq__()‎، و ‎__lt__()‎، و ‎__add__()‎، و ‎__rsub__()‎، وغيرها، للإشارة إلى أن العملية لم تعتمد (not implemented) بالنسبة إلى النوع الآخر، ويمكن أن تعاد هذه القيمة بواسطة التوابع الموضعية (in-place) الخاصة بالنظام الثنائي مثل ‎__imul__()‎ و ‎__iand__()‎ وغيرها، للسبب عينه. القيمة الصحيحة لهذا الثابت هي True.

ملاحظة:

عندما يعيد تابع ثنائي (أو موضعي) القيمة NotImplemented فإنّ مفسّر بايثون سيحاول إجراء العملية المنعكسة (reflected) على النوع الآخر (أو أي طريقة دعم تراجعي (fallback) أخرى وذلك حسب نوع العامل المستخدم). إن أعادت جميع المحاولات القيمة NotImplemented، فسيطلق المفسّر الاستثناء المناسب. 

تؤدي إعادة القيمة NotImplemented بطريقة خاطئة إلى ظهور رسالة خطأ قد تكون مضلّلة أو يمكن أن تعاد قيمة NotImplemented إلى شيفرة بايثون.

ملاحظة:

يجب التمييز بين NotImplementedError و NotImplemented بالرغم من أنّ لهما اسمين متشابهين ويستخدمان للغرض ذاته. راجع NotImplementedError للمزيد من التفاصيل حول كيفية استخدامه.

Ellipsis

هذا الثابت مشابه لـ ...، وهو قيمة خاصة يستخدم غالبًا مع عبارات الاقتطاع (slicing) الموسّعة الخاصة بأنواع حاويات البيانات المعرّفة من قبل المستخدم.

__debug__

يحمل هذا الثابت القيمة True إن جرى تشغيل بايثون دون استخدام الخيار ‎-O في سطر الأوامر. راجع أيضًا عبارة assert.

ملاحظة:

لا يمكن إعادة إسناد قيم إلى الثوابت None، False، True و __debug__، وتؤدي محاولة إسناد أي قيمة لها حتى في أسماء الخاصيات إلى إطلاق الخطأ SyntaxError، لذا يمكن أن نعتبر أنّ هذه الثوابت هي ثوابت صحيحة (true constants).

ثوابت تضيفها الوحدة site

يجري استيراد الوحدة site عند بدء تشغيل مفسّر بايثون بصورة تلقائية، إلا إذا استُخدم الخيار ‎-S في سطر الأوامر، وتضيف هذه الوحدة عددًا من الثوابت إلى مجال الأسماء الداخلي (built-in). هذه الثوابت مفيدة في مفسر بايثون التفاعلي ولا تستخدم في البرامج الاعتيادية.

quit(code=None)‎ أو exit(code=None)‎

هما كائنان يؤدي استخدامها إلى عرض رسالة مثل "Use quit() or Ctrl-D (i.e. EOF) to exit" وعند استدعائها تطلق الاستثناء SystemExit مع شيفرة الخروج المحدّدة code.

copyright أو credits

هما كائنان يؤدي طباعتهما أو استدعاؤهما إلى عرض نص حقوق النشر أو جملة الشكر والتقدير.

>>> copyright
Copyright (c) 2001-2017 Python Software Foundation.
All Rights Reserved.

Copyright (c) 2000 BeOpen.com.
All Rights Reserved.

Copyright (c) 1995-2001 Corporation for National Research Initiatives.
All Rights Reserved.

Copyright (c) 1991-1995 Stichting Mathematisch Centrum, Amsterdam.
All Rights Reserved.

license

تؤدّي طباعة هذا الكائن إلى عرض الرسالة "Type license() to see the full license text" وعند استدعائه يعرض الترخيص الكامل على شكل صفحات.

مصادر