الثوابت في بايثون
تقدم بايثون مجموعة من الثوابت، بعضها في مجال الأسماء الداخلي، أما البعض الآخر فيضاف من قبل الوحدة 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"
وعند استدعائه يعرض الترخيص الكامل على شكل صفحات.
مصادر
- صفحة Built-in Constants في توثيق بايثون الرسمي.