بايثون (لغة برمجة)
بايثون (بالإنجليزية: Python) هي لغة برمجة، عالية المستوى سهلة التعلم مفتوحة المصدر قابلة للتوسيع، تعتمد أسلوب البرمجة الكائنية. لغة بايثون هي لغة مُفسَّرة، ومُتعدِدة الاستخدامات، وتستخدم استخدامًا واسعًا في العديد من المجالات، كبناء البرامج المستقلة باستخدام الواجهات الرسومية وفي تطبيقات الويب، ويمكن استخدامها كلغة برمجة نصية للتحكم في أداء العديد من البرمجيات مثل بلندر. بشكل عام، يمكن استخدام بايثون لعمل البرامج البسيطة للمبتدئين،[ِ 1] ولإنجاز المشاريع الضخمة في الوقت نفسه. غالباً ما يُنصح المبتدؤون في ميدان البرمجة بتعلم هذه اللغة لأنها من بين أسرع اللغات البرمجية تعلماً.[34]
التنميط |
نمط برمجة: برمجة وظيفية، برمجة أمرية، برمجة كائنية التوجه، برمجة مهيكلة، انعكاس، نظام التنويع: تنويع البط، نظام الأنواع، تنويع تدريجي (ابتداءً من الإصدار 3.5)[1] |
---|---|
ظهرت في |
20 فبراير 1991[28] |
صممها | |
نظام التشغيل | |
الرخصة |
المطور | |
---|---|
الإصدار الأول | |
الإصدار الأخير |
متأثرة بـ | |
---|---|
أثرت في |
موقع الويب |
---|
طُوِّرت بايثون في معهد الرياضيات والمعلوماتية الهولندي (CWI) في مدينة أمستردام على يد جايدو فان روسم في أواخر ثمانينات القرن العشرين، وكان أول إعلان عنها في عام 1991م. كُتبت نواة اللغة باستعمال لغة سي. أطلق روسم الاسم «بايثون» على لغته تعبيرًا عن إعجابه بفِرقَة مسرحية هزلية شهيرة من بريطانيا، كانت تطلق على نفسها اسم مونتي بايثون.[35]
تتميز بايثون بمجتمعها النشط، كما أن لها الكثير من المكتبات البرمجية ذات الأغراض الخاصة التي برمجها أشخاص من ذلك المجتمع. مثلاً، هناك مكتبة باي جايم التي توفر مجموعة من الدوال من أجل برمجة الألعاب. يمكن لبايثون أيضاً التعامل مع العديد من أنواع قواعد البيانات مثل ماي إس كيو إل وغير ذلك.[36]
تدعم بايثون أنماط برمجة متعددة هي التوجيه الكائني، البرمجية جانبية التوجيه والبرمجة الوظيفية. تُستخدم بايثون عادةً مثل العديد من لغات البرمجة الديناميكية كلغة برمجة نصية. بايثون لديها نموذج مفتوح للتطوير، قائم على مجتمع بايثون البرمجي ومدعوم من مؤسسة برمجيات بايثون. والتي تحافظ على تعريف اللغة في التنفيذ المرجعي لسي بايثون.
أصل التسمية
عدلاشتق اسم بايثون من الفرقة الكوميدية البريطانية مونتي بايثون نتيجة لتأثر فان روسم بمشاهدة عروضها أثناء عمله على تطوير اللغة.[ِ 2] تظهر مونتي بايثون من حين لآخر في شيفرة بايثون البرمجية وثقافتها.[37] على سبيل المثال، السبام والبيض هي المتغيرات ما وراء البنية الأكثر شيوعاً في أدب لغة بايثون عوض متغير فو وبار التقليدي.[37][38] يلاحظ أيضًا أن وثائق بايثون الرسمية تحيل إلى المشاهد القصيرة التي قدمتها فرقة مونتي بايثون.[39][40]
تستخدم البادئة باي- (بالإنجليزية: Py-) للإشارة إلى أي شيء مُتعلِّق بهذه اللغة. على سبيل المثال، تنفيذات بايثون ومكتباتها مثل باي جايم ربط برمجي لإس دي ال ببايثون، باي كيوت وباي جتك اللذان يربطان كلاً من كيوت وجتك ببايثون.
نبذة تاريخية
عدلبدأ التفكير في إنشاء لغة بايثون أواخر الثمانينيات من القرن العشرين[35] من طرف جايدو فان روسم في معهد الرياضيات والمعلوماتية بهولندا كخليفة للغة البرمجة اي بي سي (والتي بدورها مستوحاة من سيتل).[41] وأرادوا منها أن تكون قادرة على معالجة الحالات الاستثنائية والتفاعل مع نظام التشغيل أميبا.[11] بالمقابل، لم يبدأ تنفيذ الفكرة حتى ديسمبر 1989.[42]
تحمّل فان روسم مسؤولية إدارة المشروع منفردًا، وذلك بصفته المطور الرئيسي، حتى 12 يوليو 2018، عندما أعلن عن «إجازته الدائمة» من مسؤولياته كدكتاتور بايثون الخيري لمدى الحياة، وهو اللقب الذي منحه له مجتمع بايثون ليعكس التزامه طويل الأمد بصفته صانع القرار الرئيسي للمشروع.[43] وهو يشارك الآن في القيادة عضوًا في مجلس التوجيه المكون من خمسة أشخاص.[44][45][46]
أُصدرت النسخة الثانية من بايثون (بايثون 2.0) في 16 أكتوبر 2000 مع العديد من الميزات الجديدة الرئيسية، بما في ذلك تحديد دوري (حلقي) وجامع القمامة ودعم يونيكود.[47]
أُصدرت النسخة الثالثة من بايثون (بايثون 3.0) في 3 ديسمبر 2008.وكانت مراجعة رئيسية للغة لكنها ليست متوافقة بالكامل مع الإصدارات السابقة.[48] من ميزاتها الرئيسية: الحمل العكسي في سلاسل إصدار بايثون 2.6.x [49] و2.7.x. تتضمن إصدارات بايثون 3 وظيفة 2to3
، التي تعمل تلقائيًا (جزئيًا على الأقل) على ترجمة كود (التعليمات البرمجية) بايثون 2 إلى بايثون 3.[50][ِ 3]
حددت نهاية صلاحية بايثون 2.7 في البداية عام 2015 ثم أُجل إلى عام 2020 خشية عدم إمكانية نقل مجموعة كبيرة من التعليمات البرمجية الموجودة بسهولة إلى بايثون 3.[51][52]
في يناير 2019، انتخبت نواة بايثون النشطة من المطورين بريت كانون، نيك كوغلان، باري وارسو، كارول فايلينغ وفان روسم لتشكيل الأعضاء الخمسة «للمجلس التوجيهي» لقيادة المشروع.[53]
مميزات بايثون
عدلتعد بايثون لغة برمجية سهلة نسبيًّا بالمقارنة مع جافا وسي++ إضافة إلى أنها لغة برمجة متعددة الأنماط الفكرية (برمجة متعددة البرادايم). تدعم البرمجة كائنية التوجه والبرمجة المهيكلة دعمًا كاملًا، كما تدعم بايثون البرمجة الوظيفية والبرمجة جانبية المنحى (بما في ذلك عن طريق البرمجة الوصفية[54] والكائنات الوصفية «خاصةً الطرق»).[55] يمكنها أيضًا دعم العديد من الأنماط الفكرية الأخرى عن طريق الامتدادات، بما في ذلك التصميم بالعقود[56][57] والبرمجة المنطقية.[58]
دعم للبرمجة الوظيفية
عدلزيادة على ذلك، فتصميم بايثون يقدم بعض الدعم للبرمجة الوظيفية في تقاليد ليسب. فلدى بايثون وظائف (دوال) filter
، reduce
، map
.[59] كما تتوفر على اشتمال القائمة والقواميس والمجموعات وتعبيرات المولد. تحتوي المكتبة القياسية على وحدتين (itertools وfunctools) التي تنفذ أدوات وظيفية مستعارة من هاسكل وإم أل المعيارية.[60]
تعتبر بايثون لغة سهلة للغاية لتبدأ بها في تعلم البرمجة. بايثون تحتوي تراكيب سهلة بشكل غير معتاد، كما سبق ذكره. فبايثون تسعى جاهدة إلى بناء قواعد نحوية أبسط وأقل تشويشًا مع منح المطورين خيارًا في منهجية البرمجة الخاصة بهم. على النقيض من شعار بيرل «هناك أكثر من طريقة للقيام بذلك»، فإن بايثون تتخذ الشعار «يجب -ويفضل- أن تكون هناك طريقة واحدة واضحة للقيام بذلك» فلسفةً للتصميم.[61] كتب أليكس مارتيلي، وهو زميل في مؤسسة بايثون للبرمجيات ومؤلف كتاب «بايثون»، أن «وصف شيء ما بأنه 'ذكي' لا يعتبر مجاملة في ثقافة بايثون».[62][ِ 1]
حرة ومفتوحة المصدر
عدلبايثون هي مثال على البرمجيات الحرة مفتوحة المصدر. بعبارات بسيطة، يمكنك بحرية توزيع نسخ من هذه البرمجيات، وقراءة الشيفرة (الكود) المصدرية، والقيام ببعض التغييرات عليها واستخدام أجزاء منها في برمجيات حرة جديدة، فالبرمجيات الحرة تقوم على مبدأ المجتمع الذي يتشارك المعرفة.[63][ِ 2]
لغة برمجة عالية المستوى
عدلعند تطوير البرامج ببايثون، لا داعي للاهتمام بالتفاصيل دقيقة المستوى مثل إدارة الذاكرة التي يستخدمها البايثون؛ فبايثون تستخدم نظام أنواع ديناميكيًّا ومزيجًا من التحديد الحلقي ومجمع القمامة والمحدد الحلقي (الدوري) لإدارة الذاكرة. كما تتميز أيضًا بتحليل الاسم الديناميكي (الربط المتأخر)، والذي يربط الطريقة وأسماء المتغيرات أثناء تنفيذ البرنامج.[ِ 4]
محمولة
عدلنظرا لطبيعتها البرمجية مفتوحة المصدر، فهي تعمل في العديد من المنصات. كل ما يكتب من برامج بايثون يمكن أن يعمل على أي من هذه المنصات دون أن يتطلب ذلك أي تغييرات على الإطلاق إذا كانت دقيقة بما فيه الكفاية لتجنب أي خصائص تعتمد على نظام بعينه.
يمكن استخدام بايثون على لينكس، ويندوز، فري بي إس دي، ماكينتوش، سولاريس، أو إس/2، أندرويد.[64] والعديد من أنظمة التشغيل الأخرى.[ِ 2]
كائنية التوجه
عدلتدعم بايثون البرمجة الإجرائية وكذلك البرمجة الكائنية. في اللغات إجرائية التوجه، يتمحور البرنامج حول الإجراءات أو الدوال التي ليست سوى قطع من البرامج يمكن إعادة استخدامها. وفي اللغات كائنية التوجه، يتمحور البرنامج حول الكائنات التي تجمع بين البيانات والوظائف (الطرق). وبايثون لغة قوية جدًّا وأيضًا تبسيطية للقيام بالبرمجة الكائنية خاصة عند مقارنتها بلغات مثل سي++ أو جافا.[54]
قابلة للامتداد
عدلبدلاً من دمج جميع وظائفها (طرقها) في نواتها، صممت بايثون لتكون قابلة للامتداد بدرجة كبيرة. هذه الوحدة النمطية المدمجة جعلتها شائعة بشكل خاص كوسيلة لإضافة واجهات قابلة للبرمجة إلى التطبيقات الحالية. تنبأت رؤية فان روسم للغة أساسية صغيرة مع مكتبة قياسية كبيرة ومترجمة (مجمّعة) قابلة للتوسيع بسهولة مستفيدة من أخطاء آي بي سي، التي تبنت النهج المعاكس.[35]
فلسفة بايثون
عدللخصت فلسفة اللغة الأساسية في وثيقة زن بايثون (بيب 20)، والتي تتضمن حِكمًا مثل:[61]
- الجميل أفضل من القبيح.
- الصريح أفضل من الضمني.
- البسيط أفضل من المُركّب.
- المُركّب أفضل من المعقد.
- قابلية القراءة مهمة.
يسعى مطورو بايثون جاهدين لتجنب التحسين السابق لأوانه، ويرفضون التصحيحات للأجزاء غير الحرجة من تطبيق (تنفيذ) سي بايثون المرجعي الذي من شأنه أن يوفر زيادات هامشية في السرعة على حساب الوضوح.[65] فعندما تكون السرعة مهمة، يمكن لمبرمج بايثون نقل الوظائف (الدوال) الحساسة زمنياً إلى نماذج التمديد المكتوبة بلغات مثل سي، أو باستخدام باي باي، وهو مترجم (مجمّع) آنيّ. سييثون متاح أيضًا، والذي يترجم نص بايثون لنص بلغة سي ويقوم بإجراء استدعاءات واجهة برمجة التطبيقات (API) مباشرة على مستوى اللغة سي إلى مفسر بايثون.
أحد الأهداف المهمة لمطوري بايثون هو الحفاظ على المتعة في الاستخدام.[66] ينعكس هذا في اسم اللغة - تكريمًا لمجموعة بريطانية للكوميديا السيريالية مونتي بايثون - وفي المناهج المرحة أحيانًا للبرامج التعليمية والمواد المرجعية، مثل الأمثلة التي تشير إلى البريد العشوائي والبيض (من الألبوم المشهور لمونتي بايثون) والاستعاضة عن ذلك بفو بار القياسية.[67][68]
النحو (بناء اللغة) والدلالات
عدلصممت بايثون لتكون لغة ذات مقروئية عالية، تنسيقها مرتب بصرياً؛ فهي عادةً ما تستخدم كلمات إنجليزية شائعة الاستخدام في حين تستخدم لغات البرمجة الأخرى علامات الترقيم. على النقيض من العديد من اللغات الأخرى، لا تستخدم بايثون الأقواس المعقوفة { }
لتحديد كتل الكود، والفاصلة المنقوطة ;
بعد العبارات البرمجية اختيارية. لدى بايثون استثناءات نحوية وحالات خاصة أقل بكثير من لغة سي أو باسكال.[69]
إزاحة
عدلتستخدم بايثون الإزاحة بالفراغات بدلًا من الأقواس المعقوفة { }
أو الكلمات المفتاحية لتحديد كتل الكود. الزيادة في الإزاحة تأتي بعد بعض العبارات؛ إنقاص الإزاحة علامة على انتهاء الكتلة الحالية.[70] وبالتالي، فإن البنية المرئية للبرنامج تمثل بدقة البنية الدلالية للبرنامج.[2] تُسمى هذه الميزة أحيانًا قاعدة التسلل (بالإنجليزية: off-side rule)، والتي تشترك فيها بعض اللغات الأخرى، ولكن في معظم لغات البرمجة، ليس للإزاحة أي معنًى دلالي.
العبارات البرمجية والتحكم بالتدفق
عدلتتضمن عبارات بايثون البرمجية (من بين أمور أخرى):
- عبارة مساواة (تستخدم إشارة المساواة
=
) تعمل بشكل مختلف عن بقية لغات البرمجة الأمرية وهذه الآلية الأساسية التي تتضمن «طبيعة إصدارات بايثون الخاصة بالمتغيرات» تنير الطريق للعديد من ميزات اللغة الأخرى. نأخذ مثالاً عن المساواة في لغة سي:x = 2
، يُترجم إلى «اسم المتغير المكتوب x يتلقى نسخة من القيمة العددية 2». تنسخ القيمة (اليمنى) في موقع تخزين مخصص بحيث يكون اسم المتغير (الأيسر) هو العنوان الرمزي. الذاكرة المخصصة للمتغير كبيرة بما يكفي (من المحتمل أن تكون كبيرة جدًا) للنوع المعرّف. في أبسط حالة لإسناد بايثون (assignment)، وإذا قمنا بنفس العملية في بايثون (أيx = 2
)، فإنه يُترجم إلى «اسم (generic عام) x يستقبل مرجعًا لكائن منفصل مُخصص ديناميكيًا نوعه العددي (int عدد صحيح) قيمته 2». هذا يسمى ربط الاسم بالكائن (binding). نظرًا لأن موقع تخزين الاسم لا يحتوي على القيمة المشار إليها، فمن غير المناسب تسميته متغيرًا. قد يتم إعادة الأسماء لاحقًا في أي وقت إلى كائنات من أنواع مختلفة اختلافًا كبيرًا، بما في ذلك السلاسل النصية strings والإجراءات والكائنات المعقدة مع البيانات والطرق، وغير ذلك. التعيينات (مساواة) المتتالية لقيمة مشتركة لأسماء متعددة، على سبيل المثال،x = 2
؛y = 2
؛z = 2
ينتج عن تخصيص مساحة تخزين (على الأكثر) لثلاثة أسماء وكائن عددي واحد، يتم ربط جميع الأسماء الثلاثة به. نظرًا لأن الاسم هو حامل مرجع عام (generic reference holder)، فمن غير المعقول ربط نوع بيانات ثابت به. ومع ذلك، في وقت معين، سيتم ربط الاسم بكائن ما، والذي سيكون له نوع؛ وبالتالي هناك كتابة ديناميكية. - العبارة إذا
if
، التي تنفذ مجموعة الكود بشكل مشروط (أي لا ينجز إلا إذا توفّر هذا الشرط)، وتستخدم مع عبارة عدا ذلكelse
وelif
اختصاراً لعبارة (عدا ذلك إذا else-if). - العبارة من أجل
for
، التي تتكرر فوق كائن قابل للتكرار بشكل حلقي، حيث تلتقط كل عنصر في متغير محلي لاستخدامه بواسطة مجموعة الكود البرمجي المرفقة.[ِ 5] - العبارة طالما
while
، التي تنفذ مجموعة الكود البرمجية طالما تحقق الشرط. - العبارة جرّب
try
، التي تسمح بالتعامل مع الاستثناءات المرفوعة في مجموعة الكود المرفق والتعامل معها باستثناءexcept
البنود؛ يضمن أيضًا تشغيل كود التنظيف في مجموعة الكود البرمجية الأخيرة دائمًا بغض النظر عن كيفية خروج الكتلة. - العبارة رفع
raise
تستخدم لرفع استثناء محدد أو إعادة رفع استثناء تم اكتشافه. - العبارة صنف
class
، التي تقوم بتنفيذ مجموعة من الكود وتربط مساحة الاسم المحلية الخاصة بها بصنف، لاستخدامها في البرمجة كائنية التوجه. - العبارة تعريف
def
، التي تُعرّف دالة أو طريقة. - العبارة مع
with
، من بايثون2.5 التي صدرت في سبتمبر 2006 [71]، والتي ترفق كتلة الكود داخل مدير السياق (على سبيل المثال، الحصول على قفل قبل تشغيل كتلة الكود وإطلاق القفل بعد ذلك، أو فتح ملف ثم إغلاقه)، والسماح لاكتساب الموارد الذي هو سلوك يشبه التهيئة (RAII) ويحل محل العبارة الاصطلاحية محاولة/أخيراً try/finally.[72] - العبارة توقف
break
تعني أخرج من الحلقة. - العبارة تابع
continue
تتجاوز التكرارية الحالية وتتابع للعنصر التالي. - العبارة تجاوز
pass
، والتي تُستخدم في حالة «لا عملية». تُستعمل عند الحاجة لإنشاء كتلة كود فارغة. - العبارة تأكيد
assert
، المستخدمة أثناء تصحيح الأخطاء للتحقق من الشروط التي يجب تطبيقها. - العبارة تحصيل
yield
تعيد قيمة من الدالة المولّدة. بدءاً من بايثون 2.5،yield
هي أيضاً عملية. هذا الشكل يستخدم عادةً لتنفيذ الروتينات المساعدة. - العبارة استيراد
import
، وتستخدم لاستيراد نماذج يمكن استخدام دوالها ومتغيراتها في البرنامج الحالي. يوجد ثلاث طرق لاستخدام العبارة استيرادimport
:
import <module name> [as <alias>]
from <module name> import *
from <module name> import <definition 1> [as <alias 1>], <definition 2> [as <alias 2>],...
.
- العبارة اطبع
print
والتي تغيرت إلى دالة اطبع()print
في بايثون 3.
بايثون لا تدعم التحسين الخاص الاستدعاء الذيلي أو (استمرارية الدرجة الأولى)، كما أعلن غايدو فان روسم أنه لن تدعم أبداً.[73][74] ومع ذلك، يتوفر دعم أفضل للوظائف الشبيهة بالروتين المساعد في النسخة 2.5، من خلال توسيع مولدات بايثون.[75] قبل نسخة 2.5، كانت المولدات مكررات كسولة، والتي يتم تمرير المعلومات من اتجاه واحد خارج المولد. ابتداءً من بايثون 2.5، صار من الممكن تمرير المعلومات مرة أخرى إلى دالة المولد، وبدءاً من بايثون 3.3، صار من الممكن أيضا تمرير المعلومات من خلال تعدد مستويات المكدس.[76]
تعبيرات
عدلبعض تعبيرات بايثون تشبه لغات مثل سي وجافا، بينما البعض الآخر لا:
- الجمع والطرح والضرب في بايثون مماثلة لما في جافا وسي، ولكن سلوك القسمة يختلف. هناك نوعان من القسمة في بايثون: التقسيم الكامل (أو تقسيم العدد الصحيح)
//
وتقسيم الفاصلة ا (لعائمة)/
.[77] أضافت بايثون أيضًا العامل**
من أجل الأس. - ابتداءً من بايثون 3.5، أستحدث عامل جديد
@
، لغرض استخدامه من قبل المكتبات مثل نمباي لضرب المصفوفات.[78][79] - ابتداءً من بايثون 3.8، أُدرج العامل التالي
:=
، الذي يطلق عليه «عامل الفظّ»'walrus operator'. يقوم بتعيين القيم للمتغيرات كجزء من تعبير أكبر.[80] - في بايثون
==
تقارن الأعداد من حيث القيمة (-0.0==0.0
هيtrue
)، بالمقابل في جافا تقارن عدديا بالقيمة[81] أو الكائنات بالعنوان المرجعي.[82] (من الممكن في جافا مقارنة القيمة بالكائنات عن طريق طريقة()equals
). معامل بايثونis
يستخدم ليقارن هوية الكائنات (أي المقارنة بالعنوان المرجعي). في بايثون، المقارنات يمكن تقييدها، على سبيل المثالa <= b <= c
. - بايثون تستخدم الكلمات
and
,or
,not
للعمليات البوليانية بدل من الرموز&&
,||
,!
المستخدمة في جافا ولغة سي. - بايثون لديها نوع من التعبيرات تحت مصطلح اشتمال قائمة. مدّت بايثون 2.4 قائمة الإدراك بتعبير أكثر شمولية أي تعبير المولّد.[59]
- الدوال المجهولة تنفذ باستخدام تعبير لامبدا؛ ولكنها محددة؛ وفي جسمها البرمجي يمكن أن يتواجد تعبير واحد.
- التعبيرات الشرطية في بايثون مكتوبة كالتالي
x if c else y
[83] (يختلف عن بقية اللغات الأخرى في ترتيب المعاملات من المعامل الشائعc ? x : y
عن بقية اللغات المختلفة). - تميز بايثون بين القوائم والتعديدات (tuples). القوائم مكتوبة كـ
[1, 2, 3]
، قابلة للتغيير، ولا يمكن استخدامها كمفاتيح القواميس (مفاتيح القاموس غير قابلة للتغيير في بايثون). أما التعديدات:(1, 2, 3)
، فهي غير قابلة للتغيير وبالتالي يمكن استخدامها كمفاتيح القواميس، شريطة أن تكون جميع عناصر التعديد غير قابلة للتغيير. يمكن استخدام عامل+
لسَلسَّلة لتعديدتان، والتي لا تُعدل محتوياتها بشكل مباشر، بل تنتج تعديدة جديدة تحتوي على عناصر التعديدتين المقدمة. وبالتالي، بالنظر إلى المتغيرt
الذي يساوي مبدئيًا(1, 2, 3)
, فإن إجراءt = t + (4, 5)
يقيِّم أولاًt + (4, 5)
، والذي ينتج(1, 2, 3, 4, 5)
، والتي تعين بعد ذلك إلىt
، وبالتالي «تعديل محتويات»t
بشكل فعال، مع التوافق مع الطبيعة الثابتة لكائنات التعديدة. ويجدر العلم إلى أن الأقواس اختيارية لمجموعة التعديدات في سياقات لا لبس فيها.[84] - تتميز بايثون بتفريغ تسلسل حيث يرتبط تعبيرات متعددة، كل منها يتم تقيم إلى أي شيء يمكن تعيينه إلى (متغير، خاصية قابلة للكتابة، إلخ.)، بطريقة مماثلة لتلك التي تشكل حرفيات التعديدات، وبشكل عام، يتم وضعها على الجانب الأيسر من علامة المساواة في عبارة المساواة. تتوقع العبارة وجود كائن قابل للتكرار على الجانب الأيمن من علامة المساواة ينتج نفس عدد القيم التي تحتوي عليها التعبيرات القابلة للكتابة عند تكرارها من خلاله، وسوف تتكرر من خلاله، مع تعيين كل من القيم المنتجة للتعبير المقابلة على اليسار.[85]
- بايثون لديها عامل
%
«لتنسيق سلسلة نصية». هذه الوظيفة مشابهة للتنسيق الخاص بالسلسلة النصيةprintf
في لغة سي، على سبيل المثال؛"spam=%s eggs=%d" % ("blah", 2)
تقيّم ك"spam=blah eggs=2"
. في بايثون 3 و2.6+ استكمل هذا بواسطة طريقةformat()
الخاصة ب الصنفstr
على سبيل المثال"spam={0} eggs={1}".format("blah", 2)
. بايثون 3.6 أضافت"f-strings" التالي:blah = "blah"; eggs = 2; f'spam={blah} eggs={eggs}'
.[86] - بايثون لديها حرفيات السلاسل النصية متنوعة:
- سلاسل محددة بعلامات اقتباس مفردة أو مزدوجة. على عكس شل يونكس، وبيرل واللغات المتأثرة ب ب حيث تعمل علامات الاقتباس المفردة وعلامات الاقتباس المزدوجة بشكل متماثل وظيفياً. يستخدم كلا النوعين من الخط المائل (
\
) رمزًا للهروب. أصبح استكمال السلسلة النصية متاحًا في بايثون 3.6 كـ «سلسلة منسقة حرفياً». - سلاسل نصية بعلامات اقتباس ثلاثية، التي تبدأ وتنتهي بسلسلة من ثلاث علامات اقتباس مفردة أو مزدوجة. قد تمتد على عدة أسطر وتعمل مثل توثيقات هير الموجود في شيل وبيرل وروبي.
- تشكيلة السلسلة النصية الخام، يُشار إليها بادئة السلسلة الحرفية بحرف
r
. لا يفسر تسلسل الهروب. ومن ثم تكون السلاسل النصية الأولية مفيدة عندما تكون الخطوط المائلة العكسية الحرفية شائعة، مثل التعبيرات النمطية والمسارات بنمط ويندوز. بالمقارنة مع «اقتباس-@
» (@
-quoting) في سي شارب.
- سلاسل محددة بعلامات اقتباس مفردة أو مزدوجة. على عكس شل يونكس، وبيرل واللغات المتأثرة ب ب حيث تعمل علامات الاقتباس المفردة وعلامات الاقتباس المزدوجة بشكل متماثل وظيفياً. يستخدم كلا النوعين من الخط المائل (
- لدى اقتباس بايثون quotPython تعبيرات فهرس مصفوفة شرائح المصفوفة (array slicing) في القوائم، يُشار إليها على أنها [مفتاح]
a[key]
, أو [بداية: توقف]a[start:stop]
أو [بداية: توقف: خطوة]a[start:stop:step]
. الفهارس ذات أساس صفري، والفهارس السلبية تتعلق بالنهاية. تأخذ الشرائح العناصر من فهرس البداية حتى فهرس التوقف، ولكن لا تتضمنه. تسمح معلمة الشريحة الثالثة، المسماة خطوة أو مرحلة، بتخطي العناصر وعكسها. قد تهمل فهارس الشرائح، على سبيل المثال، تُرجعa[:]
نسخة من القائمة بالكامل. كل عنصر في الشريحة هو نسخة ضحلة. - في بايثون، يفرض تمييز صارم بين التعبيرات والعبارات، على عكس اللغات مثل ليسب الشائع Common Lisp أو سكيم أو روبي. هذا يؤدي إلى تكرار بعض الوظائف. فمثلا:
- اشتمال قائمة مقابل حلقة لأجل
for
-loops. - العبارات الشرطية مقابل كتل إذا
if
البرمجية. - ال
()eval
مقابل()exec
دوال المرفقة (في ب ايثون 2،exec
هي عبارة برمجية) الأول للتعبيرات، والثاني للعبارات البرمجية.
- اشتمال قائمة مقابل حلقة لأجل
لا يمكن أن تكون العبارات جزءًا من تعبير، ل ذلك لا يمكن أن تحتوي القائمة وغيرها من الاشتمالات أو تعبيرات لامبدا (تعتبر كلها تعبيرات) على عبارات. وتبقى هناك حالة استثنائية تتمثل في أن عبارة المساواة (التعيين) مثل a = 1
لا يمكن أن تكون جزءًا من التعبير الشرطي لعبارة شرطية. وهذا يفيد في تجنب خطأ لغة سي الكلاسيكي عن غلطة في عامل التعيين =
لعامل المساواة ==
في الشروط: إذا كان (c = 1) {...} : {... }if (c = 1)
صالحًا من الناحية النحوية (ولكن غالبا هو غير مقصود) كشيفرة (كود) لغة سي بالمقابل ...:if c = 1
يسبب خطأً نحوياً في بايثون.
الطرق
عدلالطرق المطبقة على الكائنات هي دوال مرتبطة بصنف الكائن. نحوياً تمثيل. طريقة (قيمة)instance.method(argument)
. للطرق العادية والتجميل اللغوي للدوال من أجل صنف. طريقة (مثيل، قيمة)Class.method(instance, argument)
. طرق بايثون لديها معلمة صريحة تسمى ذات self
للوصول لبيانات المثيل، على النقيض من الذات الضمنية self
(أو هذه this
) في بعض لغات البرمجة الأخرى (مثل سي++ أو جافا أو سي-الكائنية أو روبي).[87]
التنويع
عدلتستخدم بايثون تنويع البط ولديها نوع للكائنات ولكن ليس لديها نوع لأسماء المتغيرات. لا يتحقق من قيود النوع في وقت التجميع؛ بدلاً من ذلك، قد تفشل العمليات على كائن ما، مما يدل على أن الكائن المحدد ليس من النوع المناسب. على الرغم من تنويعها بشكل ديناميكي، بايثون منوعة بقوة، مما يمنع العمليات غير المعرّفة جيدًا (على سبيل المثال، إضافة رقم إلى سلسلة نصية) بدلاً من محاولة فهمها بشكل صامت.
تسمح بايثون للمبرمجين بتحديد أنواعهم الخاصة باستخدام الأصناف، والتي غالبًا ما تستخدم في البرمجة الكائنية. تنشأ مثيلات جديدة الأصناف عن طريق استدعاء الصنف (على سبيل المثال، ()SpamClass
أو()EggsClass
)، الأصناف هي مثيلات من نوع صنف علوي (نفسها مثيل لنفسها)، مما يسمح بالبرمجة الوصفية والانعكاس.
قبل الإصدار 3.0، كان لدى بايثون نوعين من الأصناف: الطراز القديم والأسلوب الجديد.[88] النحو لكلا الأسلوبين هو نفسه، والفرق هو ما إذا كان كائن object
الصنف موروثًا، بشكل مباشر أو غير مباشر (جميع الأصناف من النمط الجديد ترث من الكائن object
وهي مثيلات من النوع type
). في إصدارات بايثون 2 من بايثون 2.2 وما بعده، يمكن استخدام كلا النوعين من الأصناف. أزل المطورون أصناف الطراز القديم في بايثون 3.0.
الخطة طويلة المدى هي دعم التنويع التدريجي[89] بدءاً من بايثون 3.5، تسمح اللغة نحوياً بتحديد أنواع ثابتة ولكن لا يتم التحقق منها في التنفيذ الافتراضي، سي بايثون. يدعم المدقق التجريبي للنوع الثابت والمسمى mypy التحقق من النوع في وقت التجميع.[90]
نوع | قابلية التغيير | وصف | مثال نحوي |
---|---|---|---|
bool
|
غير قابل للتغيير | قيمة بوليانية | True False
|
bytearray
|
قابل للتغيير | سلسلة من البايتات | bytearray(b'Some ASCII') bytearray(b"Some ASCII") bytearray([119, 105, 107, 105])
|
bytes
|
غير قابل للتغيير | سلسلة من البايتات | b'Some ASCII' b"Some ASCII" bytes([119, 105, 107, 105])
|
complex
|
غير قابل للتغيير | عدد معقد مكون من قسم للأعداد الحقيقية وقسم للأعداد الخيالية | 3+2.7j
|
dict
|
قابل للتغيير | مصفوفة (أو قاموس) ترابطية لأزواج المفتاح والقيمة ؛ من الممكن أن تحتوي على أنواع مختلطة (مفاتيح وقيم)، يجب أن تكون المفاتيح من النوع القابل للتجزئة (hashable). | {'key1': 1.0, 3: False} {}
|
ellipsis a
|
غير قابل للتغيير | عامل حامل مكان القطع ناقص تستخدم كفهرس في مصفوفات نمباي. | ... Ellipsis
|
float
|
غير قابل للتغيير | النقطة العائمة مزدوج الدقة. تعتمد الدقة على الآلة ولكن في الممارسة تنفذ بشكل عام كرقم 64-بت معيار أي إي إي إي 754، بـ53 بت من الدقة.[91] |
|
frozenset
|
غير قابل للتغيير | مجموعة set غير مرتبة، لا تحتوي على تكرارات؛ يمكن أن تحتوي على أنواع مختلطة، إذا كانت قابلة للحمل (hashable) | frozenset([4.0, 'string', True])
|
int
|
غير قابل للتغيير | عدد صحيح غير محدود الحجم[92] | 42
|
list
|
قابل للتغيير | قائمة، يمكن أن يحتوي أنواع مختلطة | [4.0, 'string', True] []
|
NoneType a
|
غير قابل للتغيير | كائن يمثل عدم وجود قيمة، يطلق عليها غالبًا الصفر (Null بلغات أخرى) | None
|
NotImplementedType a
|
غير قابل للتغيير | حامل مكان يمكن إرجاعه من عوامل التحميل الزائد للإشارة إلى أنواع المعالجات غير المعتمدة. | NotImplemented
|
range
|
غير قابل للتغيير | سلسلة من الأرقام شائعة الاستخدام للتكرار الحلقي عدداً معيناً في الحلقات [93] | range(1, 10) range(10, -5, -2)
|
set
|
قابل للتغيير | مجموعة غير مرتبة، لا تحتوي على نسخ مزدوجة، يمكن أن تحتوي على أنواع مختلطة، إذا كانت قابلة للحمل (hashable) | {4.0, 'string', True} set()
|
str
|
غير قابل للتغيير | حرف سلسة نصية: سلسلة من نقاط لشيفرة خاصة بيونيكود | 'Wikipedia' "Wikipedia" """Spanning
multiple
lines"""
|
tuple
|
غير قابل للتغيير | يمكن أن يحتوي عناصر مختلطة | (4.0, 'string', True) ('single element',) ()
|
^a غير قابل للوصول بشكل مباشر عن طريق الاسم
رياضيات
عدليُستخدم في بايثون الرموز المعتادة للمعاملات الحسابية (+
، -
، *
، /
)، عامل التقسيم المكمل لأسفل (دالة الجزء الصحيح) //
وعامل التقسيم مع باقي %
(حيث يمكن أن يكون الباقي سالبًا، على سبيل المثال 4% -3 ==-2
). واللغة لديها أيضًا العامل **
للرفع الأسي، على سبيل المثال 3**5 == 125
و0.5**9 == 3.0
، وعامل ضرب المصفوفة @
.[94] تعمل هذه المعاملات الحسابية كما هو الحال في الرياضيات التقليدية؛ باستخدام نفس قواعد ترتيب العمليات الحسابية، يمكن أن يكون العامل ترميزاً ضمنياً (أيضاً يمكن أن يكون الرمزان +
و-
أحاديين لتمثيل الأرقام الموجبة والسالبة على التوالي).[ِ 6] ينتج عن القسمة بين الأعداد نتائج ذات فاصلة عائمة. تغيّر سلوك القسمة في بايثون تغيرًا ملحوظًا بمرور الوقت:[95]
- في بايثون 2.1 والإصدارات السابقة، استُخدم للقسمة سلوكاً شبيهاً بالقسمة في سي. العامل
/
هو عامل قسمة عدد صحيح إذا كان كلا المعاملين عددين صحيحين وخلاف ذلك قسمة بفاصلة عائمة. التقسيم للأعداد الصحيحة يقرّب نحو 0، على سبيل المثال7/3 == 2
و7/3- == 2-
. - في بايثون 2.2 تغير أسلوب القسمة مرة أخرى إلى التقريب نحو اللانهاية السلبية، على سبيل المثال
7/3 == 2
و7/3- == 3-
. أدخل عامل تقسيم المكمل لأسفل//
. لذا3//7== 2
,3 //7-== 3-
,3// 7.5== 2.0
و3//7.5- == 3.0-
. تؤدي إضافةfrom __future__ import division
إلى أن يستخدم النموذج (module) قواعد بايثون 3.0 للقسمة (انظر أدناه). - في بايثون 3.0 تغير أسلوب القسمة لتصبح قسمة فاصلة عائمة دائمًا؛ على سبيل المثال
5/2 == 2.5
.
في مصطلحات بايثون، /
هي القسمة الحقيقية (أو ببساطة القسمة)، و//
القسمة المكملة لأسفل. ولكن، قبل الإصدار 3.0 كان العامل /
يمثل القسمة الكلاسيكية (أي الأقليدية).[95]
التقريب نحو اللانهاية السلبية تضيف الاتساق، على الرغم من اختلافها عن معظم اللغات. على سبيل المثال، المعادلة صحيحة دائمًا. والمعادلة b*(a//b) + a%b == a
صالحة لكل من القيم الموجبة والسالبة لـ a
. بالمقابل، فإن الحفاظ على صحة هذه المعادلة يعني أنه في حين أن نتيجة a%b
هي في المجال نصف المفتوح ، حيث أن b
هو عدد صحيح موجب، يجب أن تقع في المجال عندما تكون b
سالبة.[96]
يوفر بايثون دالة round
لتقريب العدد ذو الفاصلة العائمة إلى أقرب عدد صحيح. لفك التعقيد، يستخدم بايثون 3 التقريب لعدد زوجي: round(1.5)
round(2.5)
ناتج كليهما هو 2
.[97] أما الإصدارات السابقة فتستخدم تقريبًا بعيدًا عن الصفر: round(0.5)
هو 1.0
، round(-0.5)
هو 1.0−
.[98]
تسمح بايثون بالتعبيرات البوليانية بعلاقات المساواة المتعددة بطريقة تتوافق مع الاستخدام العام في الرياضيات. على سبيل المثال: التعبير a < b < c
، يتحقق بايثون ما إذا كانت a
أصغر من b
وb
أصغر من c
.[99] بعكس اللغات المشتقة من سي التي تفسر هذا التعبير بشكل مختلف: في سي، يقوم التعبير أولاً بتقييم a < b
، مما يؤدي إلى 0 أو 1، ثم تتم مقارنة هذه النتيجة مع c
.[100][ِ 7]
تستخدم بايثون حساب تدريج الدقة الاعتباطية لجميع العمليات الصحيحة. يوفر الصنف (أو النوع) Decimal
في نموذج decimal
أعداد عشرية بفاصلة عائمة وبدقة اعتباطية محددة مسبقاً والعديد من وسائل التقريب.[101] ويوفر صنف Fraction
في نموذج fractions
الدقة الاعتباطية للأعداد الكسرية.[102]
نظرًا لسعة مكتبة بايثون للرياضيات، ومكتبة الطرف الثالث نمباي التي توسع القدرات المحلية بشكل أكبر، استخدمت بايثون بشكل متكرر كلغة نصية علمية للمساعدة في حل عدة مسائل مثل معالجة البيانات العددية والتلاعب.[103][104]
الترميز
عدلابتداءً من بايثون 2.1، لاستخدام أحرف غير الأسكي في نص البرنامج، يجب عليك تحديد ترميز شفرة المصدر بشكل صريح في بداية الوحدة، على سبيل المثال:
# -*- coding: utf-8 -*-
# أو
# coding: utf-8
ولكن حتى لو اكتفيت بكتابة:
# coding: utf
«سيفهم» بايثون ما تقصد.[105]
الوراثة
عدلتدعم بايثون الوراثة المتعددة. ابتداءً من النسخة 2.3 تدعم بايثون خوارزمية سي 3، المقتبسة من لغة البرمجة ديلان[106] لحل مشكل ترتيب حل الطريقة. بينما استعملت خوازمية البحث المتعمق الذي يطرح مشاكل في حالة الوراثة الألماسية.[107][ِ 8]
أمثلة
عدلطباعة «مرحباً يا عالم!»
عدل- مثال طباعة مرحباً يا عالم «مرحباً يا عالم»[ِ 9]
# كود الطباعة في بايثون لإخراج عبارة
print("مرحباً يا عالم")
حساب العمر
عدلمثال لحساب العمر:
from datetime import * #استدعاء الكل* من مكتبة الوقت والتاريخ
dob = int(input("أدخل تاريخ الميلاد: ")) #يُطلب من المستخدم إدخال تاريخ ميلاده
# العمل على المعطيات
today = datetime.today()
year = today.year
age = int(year) - int(dob)
# طباعة عمر المستخدم
print ("{age}:عمرك هو")
استخراج العدد العاملي
عدلمثال لاستخراج العدد العاملي:
# جرب هذا الكود في بايثون 3.4.3
def Factorial(num):
new_num = 1
for count in range(num,1,-1):
new_num *= count # ضرب النتيجة بالمحسوب
return new_num
limit = 9
for n in range(0,limit+1):
print(n, '! = ' ,Factorial(n),sep='')
# بعد إدخال الكود ستحصل على:
#
# 0! = 1
# 1! = 1
# 2! = 2
# 3! = 6
# 4! = 24
# 5! = 120
# 6! = 720
# 7! = 5040
# 8! = 40320
# 9! = 362880
تكرار طباعة كلمة 5 مرات
عدلمثال لتكرار طباعه كلمة 5 مرات:
n = input(':الرجاء ادخال كلمة')
print str(n) * 5
ملاحظة لبايثون 2 استعمل raw_input
.
خوارزمية الترتيب السريع
عدلكمثال غير بديهي يمكن اعتبار خوارزمية الترتيب السريع كمثال مختصر كالتالي:
def quicksort(list):
if len(list) <= 1:
return list
pivotelement = list.pop()
left = [element for element in list if element < pivotelement]
right = [element for element in list if element >= pivotelement]
return quicksort(left) + [pivotelement] + quicksort(right)
على وجه الخصوص، هنا، يتيح تدوين القائمة للمتغيرات على اليسار واليمين تمثيلًا مضغوطًا. للمقارنة، صياغة تكرارية لهذين الخطين:
...
left, right = [], [] # انشاء قوائم فارغة لليمين واليسار
pivotelement = list.pop() # أخر عنصر في القائمة تاخذه كعنوان مرجعي
for element in list: # تكرار على العناصر المتبقية في القائمة...
if element < pivotelement: #و مقارنة العنصر المحوري Pivot-Element
left.append(element) # إذا كان اصغر،علق القائمة اليسرى
else:
right.append(element) # عدا ذلك، إذا لم يمكن اصغر، علّق القائمة اليمنى
...
هذا مجرد مثال واحد على الأعمال الكتابية التي تم توفيرها من خلال تدوين القائمة. في الواقع، في هذه الحالة تكون الصياغة التكرارية أسرع، لأنها تكرر مرة واحدة فقط في حقل «القائمة» وليس مرتين كما هو الحال في تدوين القائمة.
واجهات المستخدم الرسومية
عدلفي بايثون يمكن إنشاء واجهة مستخدم رسومية (GUI) بسرعة مع تكينتر (كما هو الحال في لغة بيرل وتي سي إل). يوجد أيضًا مجموعة متنوعة من المغلفات الأخرى التي خدمات أخرى. كما بايثون توفر ارتباطات (bindings) لمجموعات أدوات واجهة المستخدم الرسومية مثل بي.باي جتك وباي كيوت وويكس بايثون وباي أوبج سي ومجموعة أدوات الضوء السريع (فاست لايت). بالإضافة إلى تيكينتر، تحتوي بايثون أيضًا على وحدة للرسم: رسوميات «السلحفاة» (Turtle graphics).[108]
مثال لوحدة تيكينتر
عدلimport tkinter as tk
window = tk.Tk()
window.geometry("200x100")
label = tk.Label(window, text="مرحباً يا عالم")
label.pack()
def commandW():
window.destroy()
button = tk.Button(window, text="OK", command=commandW)
button.pack()
window.mainloop()
مثال لرسوميات «السلحفاة»
عدلimport turtle
from turtle import speed, reset, goto
speed(0)
reset()
turtle.x = -200
turtle.y = 200
while turtle.y != -200:
goto(turtle.x, turtle.y)
turtle.x = - turtle.x
turtle.y = - turtle.y
goto(turtle.x, turtle.y)
goto(0, 0)
turtle.y = - turtle.y
turtle.x = - turtle.x
turtle.y -= 5
رسوميات أخرى لل«سحلفاة»
عدل-
دائرة ملونة
-
نجمة
-
مربع
المكتبات
عدليعتبر الكثيرون مكتبة بايثون القياسية الكبيرة واحدة من أعظم نقاط قوة بايثون،[109] نظرا لتوفيرها أدوات تناسب العديد من المهام. كما تدعم المكتبة العديد من التنسيقات والبروتوكولات القياسية مثل امتداد البريد الإلكتروني متعدد الأغراض (MIME) وبروتوكول نقل النص الفائق (HTTP) الخاصة بتطوير تطبيقات الويب، وتدعم أيضا وحدات لإنشاء واجهات المستخدم الرسومية، والاتصال بقواعد البيانات العلائقية، وتوليد أرقام شبه عشوائية، والحساب العشري بدقة اعتباطية [110] والمعالجة بالتعبيرات النمطية، وكذا اختبار الوحدة.[ِ 4]
بعض أجزاء المكتبة القياسية تشمل الكثير من المميزات (على سبيل المثال، تنفيذ واجهة بوابة خادم ويب (WSGI)
wsgiref
يتبع PEP 333[111])، ولكن أغلب الوحدات لا تحتوي على مميزات، وتتميز عن الوحدات الأخرى من خلال التعليمات البرمجية والتوثيق الداخلي وتراكيب الاختبار. بالمقابل، فإن عددًا قليلاً فقط من الوحدات يحتاج إلى تعديل أو إعادة كتابة لعمليات التنفيذ المختلفة، نظرًا لأن معظم المكتبة القياسية هي كود بايثون متعدد المنصات.
تضمّ مكتبة بايثون مجموعة من الوحدات القياسية وبعضها مدمج مع مفسّر بايثون وتتيح الوصول إلى عمليات ليست جزءًا من اللغة، ولكن الهدف منها هو إتاحة الوصول إلى العمليات الأساسية في نظام التشغيل مثل استدعاءات النظام أو زيادة كفاءة عمل المفسّر، يمكن زيادة عدد الوحدات في المكتبة القياسية بوحدات مكتوبة في سي أو بايثون.
ابتداءً من نوفمبر 2019، يحتوي مؤشر حزمة بايثون باي باي (بالإنجليزية: Python Package Index) (PyPI)، وهو المستودع الرسمي لبرامج بايثون التابعة لجهات خارجية، على أكثر من 200,000[112] حزمة مع مجموعة واسعة من الميزات، بما في ذلك:
التطوير
عدليستعين المطورون لتطوير بايثون بشكل كبير بعملية اقتراح تحسين بايثون (PEP)، وهي الآلية الأساسية لاقتراح ميزات جديدة رئيسية، واستطلاع آراء المجتمع حول القضايا وقرارات تصميم بايثون.[115] كما يغطي نمط ترميز بايثون في PEP 8.[116] ويقوم مجتمع بايثون والمجلس التوجيهي بمراجعة الاقتراحات والتعليق عليها.[115]
يتوافق تعزيز وتحسين اللغة مع تطوير التنفيذ المرجعي سي بايثون. القائمة البريدية بايثون ديف (python-dev) هي المنتدى الأساسي لتطوير اللغة. وتُناقش حالات محددة في نظام تتبع للعلل راوند آب [الإنجليزية] المستضاف في bugs.python.org .[117] في الأصل، جرى تطوير شيفرة بايثون البرمجية في مستودع ذاتية الاستضافة بتشغيل ميركوريال، حتى يناير 2017، حيث انتقل بايثون إلى غيت هاب.[118]
هناك ثلاثة أنواع للإصدارات العامة الجديدة لسي بايثون، ويتميز كل نوع بزيادة جزء من رقم الإصدار:
- إصدارات غير متوافقة مع الإصدارات السابقة، حيث يُتوقع كسر الكود مما يجبر المستخدم أن يُحمّل يدويًا. يزيد تعداد الجزء الأول من رقم الإصدار. تحدث هذه الإصدارات بشكل غير دوري، فعلى سبيل المثال، أُصدر الإصدار 3.0 بعد 8 سنوات من 2.0.
- الإصدارات الرئيسية أو «المميزة» ، تصدر كل 18 شهرًا تقريبًا، متوافقة إلى حد كبير ولكنها تقدم ميزات جديدة. يزيد تعداد الجزء الثاني من رقم الإصدار. كل نسخة رئيسية مدعومة بإصلاحات أخطاء لعدة سنوات بعد إصدارها.[119]
- تُنشر إصدارات Bugfix،[120] التي لا تقدم ميزات جديدة، كل 3 أشهر تقريبًا وعند إصلاح عدد كاف من الأخطاء في المصدر منذ الإصدار الأخير. كما تُصحح الثغرات الأمنية في هذه الإصدارات. يزيد تعداد الجزء الثالث والأخير من رقم الإصدار.
أُعلن عن بايثون 3.9 ألفا1 في نوفمبر 2019[121] ومع اعتماد مقياس جديد يتمثل في إصدار سنوي،[122] ثم أعلن الإصدار الأول من 3.9 سيصدر في نوفمبر 2020.[123]
تُصدر أيضًا العديد من النسخ بصيغة ألفا وبيتا والنسخ المرشحة كمعاينات واختبارات قبل الإصدارات النهائية. على الرغم من وجود جدول تقريبي لكل إصدار، إلا أنه غالبًا ما يتأخر في الصدور إذا لم يكن الكود جاهزًا. يراقب فريق تطوير بايثون حالة الكود من خلال تشغيل مجموعة اختبارات للوحدة الكبيرة أثناء التطوير، واستخدام نظام BuildBot للتركيب المتواصل.[124]
المؤتمر الأكاديمي الرئيسي حول بايثون هو باي كون. هناك أيضًا برامج توجيه خاصة للبايثون، مثل باي ليديز.
بيئات التطوير
عدلأغلب بيئات تطوير بايثون (بما في ذلك سي بايثون) تتضمن حلقة القراءة - التقييم - الطباعة (REPL) مما يسمح لها بالعمل كمترجم سطر الأوامر حيث يقوم المستخدم بإدخال البيانات بشكل تسلسلي ويتلقى النتائج على الفور.
تضيف القشور (Shells) الأخرى، بما في ذلك بيئة التطوير المتكاملة للتعلم وآي بايثون، قدرات إضافية مثل الإكمال التلقائي المحسّن والاحتفاظ بحالة الجلسة وتعليم الصيغة. بالإضافة إلى بيئات التطوير المتكاملة القياسية لسطح المكتب، هناك بيئات تطوير متكاملة مستندة إلى متصفحات ويب؛ سايج مات (مخصص لتطوير برمجيات بايثون العلمية والرياضية)؛ بايثون إني وير، بيئة تطوير واستضافة تستند إلى متصفح ويب؛ وبيئة تطوير كانوبي المتكاملة، وهو بيئة تطوير متكاملة تجارية لبايثون ترتكز على الحوسبة العلمية.[125]
التنفيذات
عدلتنفيذ العنوان المرجعي
عدلسي بايثون، التنفيذ المرجعي لبايثون، مكتوب بسي، يلبي معيار سي 89 مع العديد من ميزات سي99 المحددة.[126] يقوم بتجميع برامج بايثون في كود بايت متوسط[127] ينفذ بعد ذلك بواسطة آلتها الافتراضية.[128] يوزع سي بايثون مع مكتبة قياسية كبيرة مكتوبة في مزيج من سي، وبايثون. والمكتبة متاحة للعديد من المنصات، بما في ذلك ويندوز (فيستا والإصدارات الأحدث؛ نظام التشغيل ويندوز اكس بي والإصدارات الأقدم، ولكن بايثون 2.7 غير مدعوم حتى الآن ومعظم الأنظمة الشبيهة بيونيكس الحديثة). في فترة بايثون 1 و2، كانت قابلية المنصة واحدة من أولى أولوياتها،[129] حيث كانت تدعم حتى في إم إس وأو إس/2، ولكن حاليا، انخفض الدعم للعديد من المنصات.
تنفيذات أخرى
عدلباي باي هو تنفيذ سريع، يوفر ترجمة في الوقت المناسب، متوافق مع بايثون 2.7 وبايثون 3.6.[130] وهو أسرع من سي بايثون بالمقابل، فهو لا يدعم العديد من المكتبات المكتوبة بلغة ببايثون.[131][132]
ستاكليس بايثون، انشقاق معروف لسي بايثون، ينفذ الخيوط الدقيقة دون استعمال رصة ذاكرة سي. مما يسمح بالبرامج المتزامنة بنطاق واسع.[133]
مايكروبايثون وسيركويت بايثون هي متغيرات لبايثون 3 محسنة للتحكم الدقيق وهذا يشمل ليجو مايندستورمز اي في 3.[134]
تنفيذات غير مدعومة
عدلطورت برامج تجميع بايثون آنية أخرى، ولكنها الآن غير مدعومة:
- سنة 2009، بدأت جوجل مشروعًا باسم أنلادين سوالو، بهدف تسريع مترجم بايثون خمسة أضعاف باستخدام إل إل في إم، وتحسين قدرته على تعدد الخيوط البرمجية مع آلاف النوى ،[135] بينما تعاني التنفيذات العادية من قفل المترجم العالمي.
- كان سايكو، مجمّع آنيّ متكامل مع سي بايثون ويحول «بايت كود» إلى كود الآلة في وقت التشغيل. الكود المنبعث مخصص لأنواع معينة من البيانات وهو أسرع من كود بايثون القياسي.
- في عام 2005، أصدرت نوكيا مفسر بايثون للهواتف المحمولة سلسلة 60 المسمى بايثون أس60. يتضمن العديد من النماذج من تنفيذات سي بايثون وبعض النماذج الإضافية للتكامل مع نظام التشغيل سيمبيان. حدث المشروع ليشغل على جميع متغيرات منصات S60، وتتوفر العديد من النماذج مدعومة من طرف ثالث. يدعم نوكيا N900 أيضًا بايثون مع مكتبات أدوات جتك+، مما يتيح كتابة البرامج وتشغيلها على الجهاز المستهدف.[136]
المحولات البرمجية إلى لغات أخرى
عدلتوجد العديد من المحولات البرمجية لبايثون إلى لغات أخرى كائنية عالية المستوى، إما بواسطة بايثون غير مقيد، أو مجموعة فرعية مقيدة من بايثون، أو بواسطة لغة مشابهة لبايثون كلغة مصدر:
- كايثون يترجم شيفرة (كود) مكتوبة ببايثون إلى سي.
- جوجل جرامبي يترجم شيفرة (كود) مكتوبة ببايثون إلى جو.[137][138]
- يتبع آيرن بايثون نهجا مشابها لتشغيل برمجيات مكتوبة ببايثون على NET. وقت التنفيذ المشترك.
- يتيح جايثون استخدام مكتبة أصناف جافا لبرمجيات بايثون.
- ماي إتش دي إل يترجم شيفرة (كود) مكتوبة ببايثون إلى في في إتش دي إل.
- نويتكا يترجم شيفرة (كود) مكتوبة ببايثون إلى سي++.[139]
- نيمبا تستعمل إل إل في إم لترجمة شيفرة (كود) مكتوبة ببايثون إل شيفرة الآلة.
- باي جس يترجم شيفرة (كود) مكتوبة ببايثون إلى جافا سكريبت.
- بايركس (آخر إصدار في 2010) يترجم شيفرة (كود) مكتوبة ببايثون إلى سي.
- شيد سكين (آخر إصدار في 2013) يترجم شيفرة (كود) مكتوبة ببايثون إلى سي++.
- باي تران يترجم شيفرة (كود) مكتوبة ببايثون إلى سي++.[140][141]
- إربايثون يمكنها أن تترجم لسي، استخدم لبرمجة مترجم باي باي.
الأداء
عدلقُورِن أداء مختلف تنفيذات بايثون على عبء عمل غير عددي (التوافقية) في أورو سي باي 13.[142] ثم قيس أداء بايثون مقارنة بلغات البرمجة الأخرى من خلال لعبة معايير لغة الكمبيوتر.[143]
مولدات وثائق واجهة برمجة التطبيقات
عدلتتضمن مولدات واجهة برمجة التطبيقات (API) ما يلي:
بايثون للهواتف الذكية
عدلبايثون ليست مناسبة ومحسنة لتطوير برامج الهواتف المحمولة [ِ 2] مع ذلك، فإن إصدارات بايثون 2.5 و2.6 متوافقة مع آيفون بعد تفعيل كسر الآي أو إس في الإعدادات وهواتف أندرويد بفضل تطبيق إس إل فور (SL4) أي الذي يوفر إمكانية برمجة بعض الواجهات الرسومية بفضل الدالة "android" ;إمكانية إرسال رسائل قصيرة، تشغيل الكاميرا[64]، وهز الهاتف كما هو مبين أسفله.
droid = android.Android() # عميل مرتبط بخادم محلي لإس إل فور أي
# للتحكم بهاتف آخر بعنوان 192.168.0.5، وإس إل فور أي في منفذ 9887
# يكفي كتابة : android.Android('192.168.0.5', 9887)
droid.vibrate(2.5) # هز الهاتف (محلي أو لا) لمدة 2.5 ثانية
ابتداءً من يونيو 2012، صار من الممكن تشغيل بايثون أيضًا في نظام تشغيل بلاك بيري أوس 10 بواسطة تنفيذ، في سبتمبر 2012 أصدر إصدار مخفف: «بلاكبيري تارت»[146][147] مستند إلى بايثون 3.2.2.
استخدامات
عدلمنذ 2003، صنفت بايثون ضمن أكثر لغات البرمجة شعبية في فهرس تيوبي للغات البرمجة الأكثر شعبية، وفي فبراير 2020 صنفت في المرتبة الثالثة (أي بعد جافا وسي).[148] صنفت أيضا كلغة برمجة العام لسنة 2007، 2010 و2018.[149] وحسب استبيان لموقع ستاك أوفرفلو فإن بايثون هي أسرع الغات نموا فقد تمكنت من تخطي العديد من لغات البرمجة.[ِ 1]
توصلت دراسة تجريبية إلى أن لغات البرمجة النصية، مثل بايثون، هي أكثر إنتاجية من اللغات التقليدية، مثل سي وجافا، لحل مشكلات البرمجة مثل التحكم بالسلسلة والبحث في القاموس، وخلصت إلى أن استهلاك الذاكرة غالبًا «أفضل من جافا وليس أسوأ بكثير من سي أو سي++».[150] تستخدم منظمات كبيرة بايثون كويكيبيديا، جوجل،[151] ياهو!،[152] سيرن،[153] ناسا،[154] فيسبوك،[155] أمازون، إنستغرام،[156] سبوتيفاي[157][ِ 1] وأيضا بعض الشركات الصغيرة إندستريال لايت آند ماجيك [158] وإيتا للبرمجيات.[159] كما أن شبكة التواصل الاجتماعي ريديت مكتوبة كليا ببايثون.[160]
يمكن استخدام بايثون كلغة برمجة نصية لتطبيقات الويب، مثال : عبر mod wsgi لخادم ويب أباتشي.[161] باستعمال واجهة بوابة خادم ويب، تطورت واجهة برمجة التطبيقات القياسية لتسهيل برمجة هذه التطبيقات. تدعم المنصات البرمجية لتطبيقات الويب مثل جانغو، باي لونز، بيراميد، توربو جيرز، ويب-تو-باي، تورنادو، فلاسك، بوتل [ِ 10] وزوب المطورين في تصميم وصيانة التطبيقات المعقدة. يمكن استخدام باي جس وآيرن بايثون لتطوير جانب العميل من التطبيقات القائمة على أجاكس. يمكن استخدام إس كيو إل ألشمي كمحدد للبيانات العلائقية. تويستد هو إطار عمل يبرمج التواصل بين أجهزة الحاسوب لذا استعمل في دروب بوكس.
المكتبات البرمجية كنمباي وسي باي ومات بلوت ليب تسمح باستعمال بايثون في الحوسبة العلمية.[162][163] إضافة إلى بايو بايثون وأستروباي اللتان توفران خدمات متخصصة. سايج مات هي برمجية رياضية بواجهة على شكل مفكرة قابلة للبرمجة ببايثون: تشمل أغلب مجالات الرياضيات، كالجبر، والتركيبات، والتحليل العددي، ونظرية الأعداد والتفاضل والتكامل.[164] تمكنت بايثون من أن تصير جزءا لا يتجزأ من أغلب البرمجيات كلغة برمجة نصية، وتشمل برمجيات طريقة العناصر المنتهية مثل أباكوس، برمجية للتصميم الحدودي ثلاثي الأبعاد، ومثل فري كاد، حزم رسوم متحركة كثري دي إس ماكس، وبلندر، وسينما فور دي، ولايت وايف، وهوديني، ومايا، ومودو، أوتودسك موسيون بولدير، وسوفت إيماج إكس إس آي، وبرنامج الخدع البصرية نوك، برامج معالجة الصور ثنائي الأبعاد كبرنامج جنو لمعالجة الصور،[165] وإنكسكايب، سكريبوس، بينت شوب برو،[166] وبرامج التدوين الموسيقي ككابيلا. ستعمل مصحح جنو بايثون كبرتي برنت لإظهار الهياكل المعقدة كحاويات سي++. تروج إسري لبايثون كأفضل خيار لكتابة سكربتات آركجيس.[167] كما استعملت في العديد من ألعاب الفيديو [168][169] واعتمدت كأول لغة برمجة متوفرة في محرك تطبيقات جوجل، يأتي بعدها جافا وجو.[170] تستخدم بايثون غالبا في مشاريع الذكاء الصناعي ومشاريع تعليم الآلة بمساعدة كل من المكتبات مثل تنسرفلو، كيراس، باي تورش، ساي كيت ليرن.[171][172][173][174] نظرا لأنها لغة برمجية نصية تدعم البرمجة التركيبية، بنحو بسيط، بأدوات معالجة نصية غنية، غالبًا ما تستخدم بايثون لمعالجة اللغات الطبيعية.[175]
كما أنها مضمنة في أنظمة التشغيل المختلفة مثل أغلب توزيعات لينكس [176]، أميغا أو إس 4 (يستعمل بايثون 2.7)، فري بي إس دي (كحزمة)، نت بي إس دي، أوبن بي إس دي (كحزمة) وماك أو إس ويمكن استعمال بايثون على هذه الأنظمة على سطر الأوامر. العديد من إصظارات لينكس تستعمل مثبثي برامج مكتوبون ببايثون : أوبنتو تستعمل أوبكويتي، ريدهات لينكس وفيدورا يستعملان مثبث أناكوندا. أما جنتو لينكس فتستعمل بايثون في نظام إدارة حزمها، بورتاج.
تستخدم بايثون بكثافة في صناعة أمن المعلومات، بما في ذلك التحكم بالاستغلال وتطويره.[177][178]
البيانات الضخمة، بسبب قدرة بايثون على التعامل مع البيانات بشكل سلس وتحليلها ووجود العديد من المكتبات المختصة في هذا المجال مثل باندا فتعد بايثون خيار ممتاز للعاملين في هذا المجال.[179] أغلب برمجيات شوجر لحاسوب محمول لكل طفل XO، المطورة الآن في شوجر لابز، مكتوبة ببايثون.[180] اعتمدت حواسيب رسبري باي أحادية اللوحة بايثون لغة برمجة رئيسية للمستخدم. ليبر أوفيس مكتوب جزئيا ببايثون، ويعتزم تعويض جافا ببايثون. منذ إصدار الإصدار الرابع في 3 سبتمبر 2017، صار موفر البرمجة النصية لبايثون ميزة أساسية للبرنامج.[181]
في حواسيب اللوحة الواحدة راسباري باي (مفسر بايثون) يجب في الأصل أن يكون مفسر بذاكرة قراءة فقط بايثون المدمج،[182] حتى اليوم، تعد بايثون واحدة من أكثر اللغات المفضلة لراسباري باي، ويأتي نظام التشغيل القياسي راسبيان مع مكتبة بايثون كبيرة للتحكم في الأجهزة.[ِ 11][ِ 2]
تشغيل برنامج مكتوب بلغة بايثون
عدلبما أن لغة بايثون نصية، فإنه يتوجب وجود مفسر للغة لتشغيل البرنامج، وللحصول عليه، يكفي تنزيله من موقع لغة بايثون وذلك حسب نظام التشغيل[183] يستلزم وجود محرر نصوص لكتابة برنامج بايثون حيث يُحفظ الملف بلاحقة py. بعد ذلك ادخل على سطر الأوامر واكتب:
>> python program.py
بحيث program اسم الملف، وللتعامل مباشرة مع محث لغة بايثون، اكتب في سطر الأوامر :
>> py
أو
>>python
المجتمع
عدلمجتمع بايثون
عدل- من الكلمات المستحدثات المألوفة في مجتمع بايثون كلمة pythonic، والتي لها مجموعة واسعة من المعاني المتعلقة بأسلوب البرنامج. إن القول بأن الشفرة هي pythonic يعني القول أنها تستخدم مصطلحات بايثون بشكل جيد، وأنها طبيعية أو تُظهر طلاقة في اللغة، وأنها تتوافق مع فلسفة بايثون البسيطة والتأكيد على سهولة القراءة. في المقابل، فإن التعليمات البرمجية التي يصعب فهمها أو تقرأ مثل النسخ التقريبي من لغة برمجة أخرى تسمى unpythonic.
- غالبًا ما يُشار إلى مستخدمي بايثون والمعجبين بها، وخاصة أولئك الذين يعتبرون على دراية أو خبرة بها، باسم بايثونيستاس (Pythonistas).[184][185]
لغات أثرث ببايثون
عدلظهرت بايثون في وقت متأخر نسبيًا، وبذلك خضعت لتأثير العديد من لغات البرمجة الأخرى ومنها:
- اي بي سي: نفس مسافة بادئة بايثون، وهياكل بيانات عالية المستوى (خرائط)، (في الواقع صممت بايثون لتصحيح أخطاء برمجة أي بي سي).[11][186][187][ِ 1]
- مودولا 3:[ِ 1] الحزم والوحدات، وكذا
try
وelse
وexept
[16] - سي[15]،سي++: بعض النحو كما قال جايدو فان روسم أنه استعمل بعض النحو المتناسق مع سي لكي لا يكره المبرمجون بايثون.[16][186][ِ 1]
- ليسب، سكيم: ميزات البرمجة الوظيفية (
lambda
,map
,reduce
,filter
وغيرها) [22] - جافا: الوحدات النمطية.[21][188]
- أيكون: المولدات [20]
- سمول توك: البرمجة الكائنية.[ِ 1]
لغات البرمجة التي تأثرت ببايثون
عدلأثر تصميم وفلسفة بايثون على العديد من لغات البرمجة الأخرى:
- بوو، يستخدم بوو مسافة بادئة (الإزاحة)، بناء جملة ونموذج كائن مشابه لبايثون.[189]
- كوبرا، تستخدم مسافة البادئة وبناء الجملة مماثل لبايثون، وتشير في وثيقة شكر وتقدير على أن بايثون يعتبر الأول من بين اللغات التي أثرت عليها.[190]
- كافي سكريبت، لغة برمجة تتقاطع مع جافا سكريبت، تحتوي أيضا على بنية مستوحاة من بايتون.
- إيكما سكريبت/جافا سكريبت، استعارت التكرارات والمولدات من بايثون.[191]
- جي دي سي سكريبت، لغة برمجة تشبه إلى حد بعيد لغة بايثون، مدمجة في محرك لعبة غو دوت.[192]
- غو، مصمم من أجل «سرعة العمل بلغة ديناميكية مثل بايثون»[193] وتشارك نفس البنية لتقسيم المصفوفات.
- غروفي، صُممت بدافع الرغبة في جلب فلسفة تصميم البايثون إلى جافا.[194]
- جوليا، صُممت لتكون «قابلةً للاستخدام للبرمجة العامة مثل بايثون».[195]
- نيم يستخدم نيم مسافة بادئة (الإزاحة) وبناء جملة مشابه لبايثون [196]
- روبي، صرح مبتكر روبي، يوكيهيرو ماتسوموتو،: «أردت لغة نصية أقوى من لغة بيرل، وأكثر كائنية التوجه من بايثون. ولهذا السبب قررت تصميم لغتي الخاصة».[197]
- سويفت، لغة برمجة طورتها شركة آبل، لديها بعض النحو المستوحى من بايثون.[198]
كما قلدت لغات أخرى ممارسات تطوير بايتون. على سبيل المثال، أُستخدمت ممارسة طلب مستند يصف الأساس المنطقي، والقضايا المحيطة بتغيير اللغة (في Python، PEP) في تي سي إل،[199] إرلانغ،[200] وسويفت.[201]
انتقادات
عدلفي تعريف الطريقة البرمجية يجب وضع المعلمة ذات (self) التي تتوافق مع مثيل الصنف، المطلوب استدعاء طريقتها، بوضعها صراحة كمعلمة. غالباً يبدو هذا الشكل غير أنيق برمجياً كما أنه ليس برمجة كائنية التوجه.[202] لكن ذلك ضروري لإتاحة بعض البُنى البرمجية الهامة؛ ويتناسب مع فلسفة بايثون القائلة «الصريح أفضل من المضمن».[203]
وفي الإصدار 3.0 غالباً ما يُنتقد استدعاء تعريف الطريقة لنسخة الصنف الأساسية التي تصرح بالصنف وتتطلب مثيل.حيث يُرى أنه يتناقض مع مبدأ «لا تكرر نفسك (خطواتك)». بالمقابل، يمنع ذلك إعادة التسميات.في الأخير، حلت نقطة الخلاف في بايثون 3.0.[204]
كما يُنتقد الافتقار إلى أمان التنويع الثابت في بايثون.[205]
في الأنظمة ذات المعالجات متعددة الأنوية، وفي في سي بايثون، يوجد ما يسمى قفل المفسر العالمي (Global Interpreter Lock (GIL)) الذي له أداء فعّال لتنفيذات بايثون التي يتطلب استخدامها برمجيات حاسوبية متعددة الخيوط. بيد أن هذا القيد غير موجود في جايثون وآيرن بايثون.وحتى الآن، لا توجد مخططات رسمية تحل محل قفل المفسر العالمي. بدلاً من ذلك، يوصّى باستخدام عمليات متعددة تتواصل مع بعضها البعض بدلاً من تعدد الخيوط الحاسوبية.[206][207]
في التنفيذات المنتشرة، تكون سرعة التنفيذ أبطأ من سرعة العديد من اللغات المجمّعة وتستنزف الذاكرة أكثر،[ِ 2][208] ولكن سرعتها مشابهة لبيرل،[209] بي اتش بي، [210] دارت [211]، وروبي.[212] ويرجع ذلك غالبا إلى مبدأ بايثون «وضوح الكود له الأسبقية على السرعة».[213] تنصح بعض المواقع مثل دونالد نث وتوني هورار بعدم التحسين المبكر، لذا ظهرت مشاكل في السرعة لا يمكن حلها عن طريق تحسين كود بايثون، [214] عوضا من ذلك تستخدم مجمعات (أو محولات) آنية مثل باي باي أو يستعان بدوال حساسة للوقت في اللغات منخفضة المستوى مثل سي أو كايثون.
انظر أيضًا
عدلالمراجع
عدلباللغات الأجنبية
عدل- ^ "PEP 483 -- The Theory of Type Hints". Python.org. مؤرشف من الأصل في 2020-06-14.
- ^ ا ب Guttag، John V. (12 أغسطس 2016). Introduction to Computation and Programming Using Python: With Application to Understanding Data. MIT Press. ISBN:978-0-262-52962-4.
- ^ "CoffeeScript". coffeescript.org. مؤرشف من الأصل في 2020-06-12.
- ^ "The Genie Programming Language Tutorial". مؤرشف من الأصل في 2020-06-01. اطلع عليه بتاريخ 2020-02-28.
- ^ "Perl and Python influences in JavaScript". www.2ality.com. 24 فبراير 2013. مؤرشف من الأصل في 2020-06-01. اطلع عليه بتاريخ 2015-05-15.
- ^ Rauschmayer، Axel. "Chapter 3: The Nature of JavaScript; Influences". O'Reilly، Speaking JavaScript. مؤرشف من الأصل في 2019-09-11. اطلع عليه بتاريخ 2015-05-15.
- ^ "Why We Created Julia". Julia website. فبراير 2012. مؤرشف من الأصل في 2020-05-02. اطلع عليه بتاريخ 2014-06-05.
We want something as usable for general programming as Python [...]
- ^ Ring Team (4 ديسمبر 2017). "Ring and other languages". ring-lang.net. ring-lang. مؤرشف من الأصل في 2019-02-02.
- ^ Bini، Ola (2007). Practical JRuby on Rails Web 2.0 Projects: bringing Ruby on Rails to the Java platform. Berkeley: APress. ص. 3. ISBN:978-1-59059-881-8. مؤرشف من الأصل في 2020-06-03.
- ^ Lattner، Chris (3 يونيو 2014). "Chris Lattner's Homepage". Chris Lattner. مؤرشف من الأصل في 2020-06-09. اطلع عليه بتاريخ 2014-06-03.
The Swift language is the product of tireless effort from a team of language experts، documentation gurus، compiler optimization ninjas، and an incredibly important internal dogfooding group who provided feedback to help refine and battle-test ideas. Of course، it also greatly benefited from the experiences hard-won by many other languages in the field، drawing ideas from Objective-C، Rust، Haskell، Ruby، Python، C#، CLU، and far too many others to list.
- ^ ا ب ج "Why was Python created in the first place?". General Python FAQ. Python Software Foundation. مؤرشف من الأصل في 2012-10-24. اطلع عليه بتاريخ 2007-03-22.
- ^ "Ada 83 Reference Manual (raise statement)". مؤرشف من الأصل في 2019-10-22.
- ^ Kuchling، Andrew M. (22 ديسمبر 2006). "Interview with Guido van Rossum (July 1998)". amk.ca. مؤرشف من الأصل في 1 مايو 2007. اطلع عليه بتاريخ 12 مارس 2012.
- ^ ا ب "itertools — Functions creating iterators for efficient looping — Python 3.7.1 documentation". docs.python.org. مؤرشف من الأصل في 2020-06-14.
- ^ ا ب van Rossum، Guido (1993). "An Introduction to Python for UNIX/C Programmers". Proceedings of the NLUUG Najaarsconferentie (Dutch UNIX Users Group). CiteSeerX:10.1.1.38.2023.
even though the design of C is far from ideal, its influence on Python is considerable.
- ^ ا ب ج د "Classes". The Python Tutorial. Python Software Foundation. مؤرشف من الأصل في 2012-10-23. اطلع عليه بتاريخ 2012-02-20.
It is a mixture of the class mechanisms found in C++ and Modula-3
- ^ Lundh، Fredrik. "Call By Object". effbot.org. مؤرشف من الأصل في 2019-11-23. اطلع عليه بتاريخ 2017-11-21.
replace "CLU" with "Python", "record" with "instance", and "procedure" with "function or method", and you get a pretty accurate description of Python's object model.
- ^ Simionato، Michele. "The Python 2.3 Method Resolution Order". Python Software Foundation. مؤرشف من الأصل في 2020-06-05.
The C3 method itself has nothing to do with Python, since it was invented by people working on Dylan and it is described in a paper intended for lispers
- ^ Kuchling، A. M. "Functional Programming HOWTO". Python v2.7.2 documentation. Python Software Foundation. مؤرشف من الأصل في 2012-10-24. اطلع عليه بتاريخ 2012-02-09.
- ^ ا ب Schemenauer، Neil؛ Peters، Tim؛ Hetland، Magnus Lie (18 مايو 2001). "PEP 255 – Simple Generators". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2012-02-09.
- ^ ا ب Smith، Kevin D.؛ Jewett، Jim J.؛ Montanaro، Skip؛ Baxter، Anthony (2 سبتمبر 2004). "PEP 318 – Decorators for Functions and Methods". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-03. اطلع عليه بتاريخ 2012-02-24.
- ^ ا ب "More Control Flow Tools". Python 3 documentation. Python Software Foundation. مؤرشف من الأصل في 2016-06-04. اطلع عليه بتاريخ 2015-07-24.
- ^ وصلة مرجع: https://www.python.org/doc/essays/comparisons/. الوصول: 19 أغسطس 2016.
- ^ وصلة مرجع: http://www.oznetnerd.com/python-strong-dynamically-typed-language/. الوصول: 5 يوليو 2018.
- ^ وصلة مرجع: https://docs.python.org/3/howto/functional.html. الوصول: 19 أغسطس 2016.
- ^ وصلة مرجع: https://www.python.org/doc/essays/blurb/. الوصول: 19 أغسطس 2016.
- ^ ا ب وصلة مرجع: https://docs.python.org/3/faq/general.html#what-is-python. الوصول: 12 سبتمبر 2017.
- ^ ا ب ج "History and License - Python documentation". اطلع عليه بتاريخ 2016-08-19.
- ^ "History and License - Python documentation". اطلع عليه بتاريخ 2019-07-03.
- ^ "Download Python".
- ^ "History and License - Python documentation".
- ^ ا ب "Python Insider: Python 3.13.1, 3.12.8, 3.11.11, 3.10.16 and 3.9.21 are now available". 3 ديسمبر 2024. اطلع عليه بتاريخ 2024-12-04.
- ^ ا ب وصلة مرجع: https://api.github.com/repos/python/cpython. الوصول: 29 يوليو 2018.
- ^ Kuhlman، Dave. "A Python Book: Beginning Python, Advanced Python, and Python Exercises". Section 1.1. مؤرشف من الأصل (PDF) في 23 يونيو 2012.
- ^ ا ب ج Venners، Bill (13 يناير 2003). "The Making of Python". Artima Developer. Artima. مؤرشف من الأصل في 2019-04-27. اطلع عليه بتاريخ 2007-03-22.
- ^ "About Python". Python Software Foundation. مؤرشف من الأصل في 2023-05-08. اطلع عليه بتاريخ 2012-04-24., second section "Fans of Python use the phrase "batteries included" to describe the standard library, which covers everything from asynchronous processing to zip files."
- ^ ا ب "Whetting Your Appetite". The Python Tutorial. Python Software Foundation. مؤرشف من الأصل في 2012-10-26. اطلع عليه بتاريخ 2012-02-20.
- ^ "In Python, should I use else after a return in an if block?". ستاك أوفرفلو. Stack Exchange. 17 فبراير 2011. مؤرشف من الأصل في 2019-06-20. اطلع عليه بتاريخ 2011-05-06.
- ^ Lutz, Mark (2009). Learning Python: Powerful Object-Oriented Programming (بالإنجليزية). O'Reilly Media, Inc. p. 17. ISBN:9781449379322. Archived from the original on 2020-06-15.
- ^ Fehily, Chris (2002). Python (بالإنجليزية). Peachpit Press. p. xv. ISBN:9780201748840. Archived from the original on 2012-01-14.
- ^ van Rossum، Guido (29 أغسطس 2000). "SETL (was: Lukewarm about range literals)" (Mailing list). مؤرشف من الأصل في 2018-07-14. اطلع عليه بتاريخ 2011-03-13.
- ^ van Rossum، Guido (20 يناير 2009). "A Brief Timeline of Python". The History of Python. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2009-01-20.
- ^ Fairchild، Carlie (12 يوليو 2018). "Guido van Rossum Stepping Down from Role as Python's Benevolent Dictator For Life". Linux Journal. مؤرشف من الأصل في 2020-06-11. اطلع عليه بتاريخ 2018-07-13.
- ^ "Guido van Rossum Stepping Down from Role as Python's Benevolent Dictator For Life | Linux Journal". www.linuxjournal.com (بالإنجليزية). Archived from the original on 2020-06-11.
- ^ "Python boss Guido van Rossum steps down after 30 years". The Inquirer (بالإنجليزية). Archived from the original on 2019-12-19.
- ^ "PEP 8100". python. Python Software Foundation. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2019-05-04.
- ^ Kuchling، A. M.؛ Zadka، Moshe (16 أكتوبر 2000). "What's New in Python 2.0". Python Software Foundation. مؤرشف من الأصل في 2012-10-23. اطلع عليه بتاريخ 2012-02-11.
- ^ "Python 3.0 Release". Python Software Foundation. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2009-07-08.
- ^ van Rossum، Guido (5 أبريل 2006). "PEP 3000 – Python 3000". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2016-03-03. اطلع عليه بتاريخ 2009-06-27.
- ^ "Automated Python 2 to 3 code translation — Python Documentation". مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2018-02-11.
- ^ "PEP 373 -- Python 2.7 Release Schedule". python.org. مؤرشف من الأصل في 2020-05-19. اطلع عليه بتاريخ 2017-01-09.
- ^ "PEP 466 -- Network Security Enhancements for Python 2.7.x". python.org. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2017-01-09.
- ^ "PEP 8100". Python Software Foundation. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2019-05-04.
- ^ ا ب The Cain Gang Ltd. "Python Metaclasses: Who? Why? When?" (PDF). مؤرشف من الأصل (PDF) في 30 مايو 2009. اطلع عليه بتاريخ 27 يونيو 2009.
- ^ "3.3. Special method names". The Python Language Reference. Python Software Foundation. مؤرشف من الأصل في 2018-12-15. اطلع عليه بتاريخ 2009-06-27.
- ^ "PyDBC: method preconditions, method postconditions and class invariants for Python". مؤرشف من الأصل في 2019-11-23. اطلع عليه بتاريخ 2011-09-24.
- ^ "Contracts for Python". مؤرشف من الأصل في 2020-06-15. اطلع عليه بتاريخ 2011-09-24.
- ^ "PyDatalog". مؤرشف من الأصل في 2020-06-13. اطلع عليه بتاريخ 2012-07-22.
- ^ ا ب Hettinger، Raymond (30 يناير 2002). "PEP 289 – Generator Expressions". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2012-02-19.
- ^ "6.5 itertools – Functions creating iterators for efficient looping". Docs.python.org. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2016-11-22.
- ^ ا ب Peters، Tim (19 أغسطس 2004). "PEP 20 – The Zen of Python". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-03. اطلع عليه بتاريخ 2008-11-24.
- ^ Martelli، Alex؛ Ravenscroft، Anna؛ Ascher، David (2005). Python Cookbook, 2nd Edition. أوريلي ميديا. ص. 230. ISBN:978-0-596-00797-3. مؤرشف من الأصل في 2019-11-25.
- ^ https://gdevelop-app.com/ نسخة محفوظة 2020-06-16 على موقع واي باك مشين.
- ^ ا ب Google Code Archive - Long-term storage for Google Code Project Hosting نسخة محفوظة 19 مايو 2015 على موقع واي باك مشين.
- ^ "Ebeab.com". ebeab.com. مؤرشف من الأصل في 2020-06-05.
- ^ "General Python FAQ". Python v2.7.3 documentation. Docs.python.org. مؤرشف من الأصل في 2020-05-09. اطلع عليه بتاريخ 2012-12-03.
- ^ "15 Ways Python Is a Powerful Force on the Web". مؤرشف من الأصل في 2019-05-11.
- ^ "8.18. pprint — Data pretty printer — Python 2.7.18rc1 documentation". docs.python.org. مؤرشف من الأصل في 2020-06-03.
- ^ "Is Python a good language for beginning programmers?". General Python FAQ. Python Software Foundation. مؤرشف من الأصل في 2012-10-24. اطلع عليه بتاريخ 2007-03-21.
- ^ "Myths about indentation in Python". Secnetix.de. مؤرشف من الأصل في 2018-02-18. اطلع عليه بتاريخ 2011-04-19.
- ^ "Python 2.5 Release". Python.org. مؤرشف من الأصل في 2019-08-04.
- ^ "Highlights: Python 2.5". Python.org. مؤرشف من الأصل في 2019-08-04.
- ^ van Rossum، Guido (22 أبريل 2009). "Tail Recursion Elimination". Neopythonic.blogspot.be. مؤرشف من الأصل في 2018-05-19. اطلع عليه بتاريخ 2012-12-03.
- ^ van Rossum، Guido (9 فبراير 2006). "Language Design Is Not Just Solving Puzzles". Artima forums. Artima. مؤرشف من الأصل في 2020-01-17. اطلع عليه بتاريخ 2007-03-21.
- ^ van Rossum، Guido؛ Eby، Phillip J. (10 مايو 2005). "PEP 342 – Coroutines via Enhanced Generators". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-05-29. اطلع عليه بتاريخ 2012-02-19.
- ^ "PEP 380". Python.org. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2012-12-03.
- ^ "division". python.org. مؤرشف من الأصل في 2020-07-02.
- ^ "PEP 0465 -- A dedicated infix operator for matrix multiplication". python.org. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2016-01-01.
- ^ "Python 3.5.1 Release and Changelog". python.org. مؤرشف من الأصل في 2020-05-14. اطلع عليه بتاريخ 2016-01-01.
- ^ "What's New In Python 3.8". مؤرشف من الأصل في 2020-06-08. اطلع عليه بتاريخ 2019-10-14.
- ^ "Chapter 15. Expressions - 15.21.1. Numerical Equality Operators == and !=". أوراكل. مؤرشف من الأصل في 2020-06-07. اطلع عليه بتاريخ 2016-08-28.
- ^ "Chapter 15. Expressions - 15.21.3. Reference Equality Operators == and !=". Oracle Corporation. مؤرشف من الأصل في 2020-06-07. اطلع عليه بتاريخ 2016-08-28.
- ^ van Rossum، Guido؛ Hettinger، Raymond (7 فبراير 2003). "PEP 308 – Conditional Expressions". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2011-07-13.
- ^ "4. Built-in Types — Python 3.6.3rc1 documentation". python.org. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2017-10-01.
- ^ "5.3. Tuples and Sequences — Python 3.7.1rc2 documentation". python.org. مؤرشف من الأصل في 2020-06-10. اطلع عليه بتاريخ 2018-10-17.
- ^ "PEP 498 -- Literal String Interpolation". python.org. مؤرشف من الأصل في 2020-06-15. اطلع عليه بتاريخ 2017-03-08.
- ^ "Why must 'self' be used explicitly in method definitions and calls?". Design and History FAQ. Python Software Foundation. مؤرشف من الأصل في 2012-10-24. اطلع عليه بتاريخ 2012-02-19.
- ^ "The Python Language Reference, section 3.3. New-style and classic classes, for release 2.7.1". مؤرشف من الأصل في 2012-10-26. اطلع عليه بتاريخ 2011-01-12.
- ^ "Type hinting for Python". LWN.net. 24 ديسمبر 2014. مؤرشف من الأصل في 2019-06-20. اطلع عليه بتاريخ 2015-05-05.
- ^ "mypy - Optional Static Typing for Python". مؤرشف من الأصل في 2020-06-06. اطلع عليه بتاريخ 2017-01-28.
- ^ "15. Floating Point Arithmetic: Issues and Limitations — Python 3.8.3 documentation". docs.python.org. مؤرشف من الأصل في 2020-06-06. اطلع عليه بتاريخ 2020-06-06.
almost all platforms map Python floats to IEEE-754 double precision
- ^ Zadka، Moshe؛ van Rossum، Guido (11 مارس 2001). "PEP 237 – Unifying Long Integers and Integers". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-05-28. اطلع عليه بتاريخ 2011-09-24.
- ^ "Built-in Types". مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2019-10-03.
- ^ "PEP 465 -- A dedicated infix operator for matrix multiplication". python.org. مؤرشف من الأصل في 2020-05-29.
- ^ ا ب Zadka، Moshe؛ van Rossum، Guido (11 مارس 2001). "PEP 238 – Changing the Division Operator". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-05-28. اطلع عليه بتاريخ 2013-10-23.
- ^ "Why Python's Integer Division Floors". مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2010-08-25.
- ^ "round"، The Python standard library, release 3.2, §2: Built-in functions، مؤرشف من الأصل في 2012-10-25، اطلع عليه بتاريخ 2011-08-14
- ^ "round"، The Python standard library, release 2.7, §2: Built-in functions، مؤرشف من الأصل في 2012-10-27، اطلع عليه بتاريخ 2011-08-14
- ^ Beazley، David M. (2009). Python Essential Reference (ط. 4th). ص. 66. مؤرشف من الأصل في 2020-06-14.
- ^ Kernighan، Brian W.؛ Ritchie، Dennis M. (1988). The C Programming Language (ط. 2nd). ص. 206.
- ^ Batista، Facundo. "PEP 0327 -- Decimal Data Type". Python.org. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2015-09-26.
- ^ "What's New in Python 2.6 — Python v2.6.9 documentation". docs.python.org. مؤرشف من الأصل في 2019-12-23. اطلع عليه بتاريخ 2015-09-26.
- ^ "10 Reasons Python Rocks for Research (And a Few Reasons it Doesn't) — Hoyt Koepke". www.stat.washington.edu. مؤرشف من الأصل في 2020-05-31. اطلع عليه بتاريخ 2019-02-03.
- ^ Shell، Scott (17 يونيو 2014). "An introduction to Python for scientific computing" (PDF). مؤرشف من الأصل (PDF) في 2019-02-04. اطلع عليه بتاريخ 2019-02-03.
- ^ PEP 8 - Style Guide for Python Code | Python.org نسخة محفوظة 3 يوليو 2020 على موقع واي باك مشين.
- ^ Kim Barrett؛ Bob Cassels؛ Paul Haahr؛ David A. Moon؛ Keith Playford؛ P. Tucker Withington. A monotonic superclass linearization for Dylan. ج. 31. ص. 69–82. DOI:10.1145/236337.236343. مؤرشف من الأصل في 2016-04-29.
{{استشهاد بكتاب}}
: الوسيط غير المعروف|année=
تم تجاهله يقترح استخدام|date=
(مساعدة)، الوسيط غير المعروف|mois=
تم تجاهله يقترح استخدام|date=
(مساعدة)، والوسيط غير المعروف|périodique=
تم تجاهله يقترح استخدام|publisher=
(مساعدة) - ^ The Python 2.3 Method Resolution Order نسخة محفوظة 5 يونيو 2020 على موقع واي باك مشين.
- ^ Pmw - Python megawidgets نسخة محفوظة 2020-02-15 على موقع واي باك مشين.
- ^ Piotrowski، Przemyslaw (يوليو 2006). "Build a Rapid Web Development Environment for Python Server Pages and Oracle". Oracle Technology Network. Oracle. مؤرشف من الأصل في 2019-04-02. اطلع عليه بتاريخ 2012-03-12.
- ^ Batista، Facundo (17 أكتوبر 2003). "PEP 327 – Decimal Data Type". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2008-11-24.
- ^ Eby، Phillip J. (7 ديسمبر 2003). "PEP 333 – Python Web Server Gateway Interface v1.0". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2012-02-19.
- ^ Debill، Erik. "Module Counts". ModuleCounts. مؤرشف من الأصل في 2020-06-12. اطلع عليه بتاريخ 2019-11-05.
- ^ "Pillow — Pillow (PIL Fork) 7.1.2 documentation". pillow.readthedocs.io. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2020-06-15.
- ^ "20+ Python Web Scraping Examples (Beautiful Soup & Selenium) - Like Geeks". likegeeks.com. 5 ديسمبر 2017. مؤرشف من الأصل في 2020-05-12. اطلع عليه بتاريخ 2018-03-12.
- ^ ا ب Warsaw، Barry؛ Hylton، Jeremy؛ Goodger، David (13 يونيو 2000). "PEP 1 – PEP Purpose and Guidelines". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-06. اطلع عليه بتاريخ 2011-04-19.
- ^ "PEP 8 -- Style Guide for Python Code". Python.org. مؤرشف من الأصل في 2020-06-24.
- ^ Cannon، Brett. "Guido, Some Guys, and a Mailing List: How Python is Developed". python.org. Python Software Foundation. مؤرشف من الأصل في 2009-06-01. اطلع عليه بتاريخ 2009-06-27.
- ^ "Python Developer's Guide". مؤرشف من الأصل في 2020-05-13.
- ^ Norwitz، Neal (8 أبريل 2002). "[Python-Dev] Release Schedules (was Stability & change)". مؤرشف من الأصل في 2018-12-15. اطلع عليه بتاريخ 2009-06-27.
- ^ Aahz؛ Baxter، Anthony (15 مارس 2001). "PEP 6 – Bug Fix Releases". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2009-06-27.
- ^ "What's New In Python 3.9". Python. مؤرشف من الأصل في 2020-05-13. اطلع عليه بتاريخ 2019-11-28.
- ^ "PEP 602 -- Annual Release Cycle for Python". Python.org (بالإنجليزية). Archived from the original on 2020-06-14. Retrieved 2019-11-06.
- ^ "PEP 596 -- Python 3.9 Release Schedule". Python.org (بالإنجليزية). Archived from the original on 2020-06-04. Retrieved 2019-11-06.
- ^ "Python Buildbot". Python Developer’s Guide. Python Software Foundation. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2011-09-24.
- ^ Enthought، Canopy. "Canopy". www.enthought.com. مؤرشف من الأصل في 2017-07-15. اطلع عليه بتاريخ 2016-08-20.
- ^ van Rossum، Guido (5 يونيو 2001). "PEP 7 – Style Guide for C Code". Python Enhancement Proposals. Python Software Foundation. مؤرشف من الأصل في 2020-06-01. اطلع عليه بتاريخ 2008-11-24.
- ^ "CPython byte code". Docs.python.org. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2016-02-16.
- ^ "Python 2.5 internals" (PDF). مؤرشف من الأصل (PDF) في 2012-08-06. اطلع عليه بتاريخ 2011-04-19.
- ^ "An Interview with Guido van Rossum". Oreilly.com. مؤرشف من الأصل في 2014-07-16. اطلع عليه بتاريخ 2008-11-24.
- ^ "PyPy compatibility". Pypy.org. مؤرشف من الأصل في 2020-06-06. اطلع عليه بتاريخ 2012-12-03.
- ^ "speed comparison between CPython and Pypy". Speed.pypy.org. مؤرشف من الأصل في 2020-06-01. اطلع عليه بتاريخ 2012-12-03.
- ^ Shaw، Anthony (30 مارس 2018). "Which is the fastest version of Python?". Hacker Noon. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2019-12-20.
- ^ "Application-level Stackless features — PyPy 2.0.2 documentation". Doc.pypy.org. مؤرشف من الأصل في 2020-06-04. اطلع عليه بتاريخ 2013-07-17.
- ^ "Python-for-EV3". LEGO Education (بالإنجليزية). Archived from the original on 2020-06-07. Retrieved 2019-04-17.
- ^ "Plans for optimizing Python". Google Project Hosting. 15 ديسمبر 2009. مؤرشف من الأصل في 2016-04-11. اطلع عليه بتاريخ 2011-09-24.
- ^ "Python on the Nokia N900". Stochastic Geometry. 29 أبريل 2010. مؤرشف من الأصل في 2019-06-20.
- ^ "google/grumpy". 10 أبريل 2020. مؤرشف من الأصل في 2020-04-15 – عبر GitHub.
- ^ "Projects". opensource.google. مؤرشف من الأصل في 2020-04-24.
- ^ "Nuitka Home | Nuitka Home". nuitka.net (بالإنجليزية). Archived from the original on 2020-05-30. Retrieved 2017-08-18.
- ^ Borderies، Olivier (24 يناير 2019). "Pythran: Python at C++ speed !". Medium. مؤرشف من الأصل في 2020-03-25.
- ^ "Pythran — Pythran 0.9.5 documentation". pythran.readthedocs.io. مؤرشف من الأصل في 2020-02-19.
- ^ Murri، Riccardo (2013). "Performance of Python runtimes on a non-numeric scientific code". European Conference on Python in Science (EuroSciPy). arXiv:1404.6388. Bibcode:2014arXiv1404.6388M.
- ^ "The Computer Language Benchmarks Game". مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2020-04-30.
- ^ pydoc نسخة محفوظة 3 يونيو 2018 على موقع واي باك مشين.
- ^ Overview — Sphinx 4.0.0+ documentation نسخة محفوظة 3 يناير 2016 على موقع واي باك مشين.
- ^ blackberry-py على بيت باكيت نسخة محفوظة 23 مايو 2015 على موقع واي باك مشين.
- ^ BlackBerry-Tart Preview نسخة محفوظة 4 نوفمبر 2016 على موقع واي باك مشين.
- ^ "TIOBE Index". TIOBE - The Software Quality Company. مؤرشف من الأصل في 2020-06-14. اطلع عليه بتاريخ 2017-03-07.
- ^ TIOBE Software Index (2015). "TIOBE Programming Community Index Python". مؤرشف من الأصل في 2015-09-07. اطلع عليه بتاريخ 2015-09-10.
- ^ Prechelt، Lutz (14 مارس 2000). "An empirical comparison of C, C++, Java, Perl, Python, Rexx, and Tcl" (PDF). مؤرشف من الأصل (PDF) في 2020-01-03. اطلع عليه بتاريخ 2013-08-30.
- ^ "Quotes about Python". Python Software Foundation. مؤرشف من الأصل في 2020-06-03. اطلع عليه بتاريخ 2012-01-08.
- ^ "Organizations Using Python". Python Software Foundation. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2009-01-15.
- ^ "Python : the holy grail of programming". CERN Bulletin. CERN Publications ع. 31/2006. 31 يوليو 2006. مؤرشف من الأصل في 2018-12-15. اطلع عليه بتاريخ 2012-02-11.
- ^ Shafer، Daniel G. (17 يناير 2003). "Python Streamlines Space Shuttle Mission Design". Python Software Foundation. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2008-11-24.
- ^ "Tornado: Facebook's Real-Time Web Framework for Python - Facebook for Developers". Facebook for Developers (بالإنجليزية الأمريكية). Archived from the original on 2019-09-03. Retrieved 2018-06-19.
- ^ "What Powers Instagram: Hundreds of Instances, Dozens of Technologies". Instagram Engineering. مؤرشف من الأصل في 2020-06-15. اطلع عليه بتاريخ 2019-05-27.
- ^ "How we use Python at Spotify". Spotify Labs (بالإنجليزية الأمريكية). 20 Mar 2013. Archived from the original on 2020-06-10. Retrieved 2018-07-25.
- ^ Fortenberry، Tim (17 يناير 2003). "Industrial Light & Magic Runs on Python". Python Software Foundation. مؤرشف من الأصل في 2020-06-06. اطلع عليه بتاريخ 2012-02-11.
- ^ Taft، Darryl K. (5 مارس 2007). "Python Slithers into Systems". eWeek.com. Ziff Davis Holdings. مؤرشف من الأصل في 2023-05-22. اطلع عليه بتاريخ 2011-09-24.
- ^ GitHub - reddit-archive/reddit: historical code from reddit.com.، The Reddit Archives، 19 مارس 2019، مؤرشف من الأصل في 2020-06-01، اطلع عليه بتاريخ 2019-03-20
- ^ "Usage statistics and market share of Python for websites". 2012. مؤرشف من الأصل في 2023-05-22. اطلع عليه بتاريخ 2012-12-18.
- ^ Oliphant، Travis (2007). "Python for Scientific Computing". Computing in Science and Engineering. ج. 9 ع. 3: 10–20. Bibcode:2007CSE.....9c..10O. CiteSeerX:10.1.1.474.6460. DOI:10.1109/MCSE.2007.58. ISSN:1521-9615. مؤرشف من الأصل في 2020-06-15.
- ^ Millman، K. Jarrod؛ Aivazis، Michael (2011). "Python for Scientists and Engineers". Computing in Science and Engineering. ج. 13 ع. 2: 9–12. Bibcode:2011CSE....13b...9M. DOI:10.1109/MCSE.2011.36. مؤرشف من الأصل في 2019-02-19.
- ^ Science education with SageMath، Innovative Computing in Science Education، مؤرشف من الأصل في 2020-06-15، اطلع عليه بتاريخ 2019-04-22
- ^ "Installers for GIMP for Windows - Frequently Asked Questions". 26 يوليو 2013. مؤرشف من الأصل في 17 يوليو 2013. اطلع عليه بتاريخ 26 يوليو 2013.
- ^ "jasc psp9components". مؤرشف من الأصل في 2008-03-19.
- ^ "About getting started with writing geoprocessing scripts". ArcGIS Desktop Help 9.2. Environmental Systems Research Institute. 17 نوفمبر 2006. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2012-02-11.
- ^ CCP porkbelly (24 أغسطس 2010). "Stackless Python 2.7". EVE Community Dev Blogs. سي سي بي جيمز . مؤرشف من الأصل في 2017-12-01.
As you may know, EVE has at its core the programming language known as Stackless Python.
{{استشهاد ويب}}
: صيانة الاستشهاد: علامات ترقيم زائدة (link) - ^ Caudill، Barry (20 سبتمبر 2005). "Modding Sid Meier's Civilization IV". Sid Meier's Civilization IV Developer Blog. العاب فيراكسيس. مؤرشف من الأصل في 2 ديسمبر 2010.
we created three levels of tools... The next level offers Python and XML support, letting modders with more experience manipulate the game world and everything in it.
- ^ "Python Language Guide (v1.0)". Google Documents List Data API v1.0. مؤرشف من الأصل في 15 يوليو 2010.
- ^ Dean، Jeff؛ Monga، Rajat؛ وآخرون (9 نوفمبر 2015). "TensorFlow: Large-scale machine learning on heterogeneous systems" (PDF). TensorFlow.org. Google Research. مؤرشف من الأصل (PDF) في 2020-04-19. اطلع عليه بتاريخ 2015-11-10.
- ^ Piatetsky، Gregory. "Python eats away at R: Top Software for Analytics, Data Science, Machine Learning in 2018: Trends and Analysis". KDnuggets. KDnuggets. مؤرشف من الأصل في 2020-06-09. اطلع عليه بتاريخ 2018-05-30.
- ^ "Who is using scikit-learn? — scikit-learn 0.20.1 documentation". scikit-learn.org. مؤرشف من الأصل في 2020-05-06.
- ^ Jouppi، Norm. "Google supercharges machine learning tasks with TPU custom chip". Google Cloud Platform Blog. مؤرشف من الأصل في 2018-10-05. اطلع عليه بتاريخ 2016-05-19.
- ^ "Natural Language Toolkit — NLTK 3.5b1 documentation". www.nltk.org. مؤرشف من الأصل في 2020-06-13.
- ^ "Python Setup and Usage". Python Software Foundation. مؤرشف من الأصل في 2020-06-17. اطلع عليه بتاريخ 2020-01-10.
- ^ "Immunity: Knowing You're Secure". مؤرشف من الأصل في 16 February 2009. اطلع عليه بتاريخ أغسطس 2020.
{{استشهاد ويب}}
: تحقق من التاريخ في:|تاريخ الوصول=
(مساعدة) - ^ "Core Security". Core Security. مؤرشف من الأصل في 2020-06-09.
- ^ pandas - Python Data Analysis Library نسخة محفوظة 7 يوليو 2020 على موقع واي باك مشين.
- ^ "What is Sugar?". Sugar Labs. مؤرشف من الأصل في 2009-01-09. اطلع عليه بتاريخ 2012-02-11.
- ^ "4.0 New Features and Fixes". LibreOffice.org. مؤسسة الوثيقة . 2013. مؤرشف من الأصل في 2014-02-09. اطلع عليه بتاريخ 2013-02-25.
{{استشهاد ويب}}
: صيانة الاستشهاد: علامات ترقيم زائدة (link) - ^ Zühlke، Karin. "Erstmals »Live on stage«: Farnell zeigt den Raspberry Pi Nachwuchs". مؤرشف من الأصل في 2019-07-03.
- ^ نزل المفسر حسب النظام الذي تعمل عليه نسخة محفوظة 17 أبريل 2018 على موقع واي باك مشين.
- ^ Goodger، David. "Code Like a Pythonista: Idiomatic Python". مؤرشف من الأصل في 2014-05-27. اطلع عليه بتاريخ 2009-03-24.
- ^ "How to think like a Pythonista". مؤرشف من الأصل في 2018-03-23.
- ^ ا ب Foreword for «Programming Python» (1st ed.) نسخة محفوظة 14 يونيو 2020 على موقع واي باك مشين.
- ^ The Making of Python نسخة محفوظة 6 يونيو 2017 على موقع واي باك مشين.
- ^ Результаты одной из попыток сравнения نسخة محفوظة 2012-08-31 على موقع واي باك مشين.
- ^ "Gotchas for Python Users". boo.codehaus.org. Codehaus Foundation. مؤرشف من الأصل في 11 ديسمبر 2008. اطلع عليه بتاريخ 24 نوفمبر 2008.
- ^ Esterbrook، Charles. "Acknowledgements". cobra-language.com. Cobra Language. مؤرشف من الأصل في 2019-10-20. اطلع عليه بتاريخ 2010-04-07.
- ^ "Proposals: iterators and generators [ES4 Wiki]". wiki.ecmascript.org. مؤرشف من الأصل في 2007-10-20. اطلع عليه بتاريخ 2008-11-24.
- ^ "FAQ: What is GDScript and why should I use it?". مؤرشف من الأصل في 2020-05-19.
- ^ Kincaid، Jason (10 نوفمبر 2009). "Google's Go: A New Programming Language That's Python Meets C++". TechCrunch. مؤرشف من الأصل في 2020-06-05. اطلع عليه بتاريخ 2010-01-29.
- ^ Strachan، James (29 أغسطس 2003). "Groovy – the birth of a new dynamic language for the Java platform". مؤرشف من الأصل في 2007-04-05. اطلع عليه بتاريخ 2007-06-11.
- ^ "Why We Created Julia". Julia website. فبراير 2012. مؤرشف من الأصل في 2020-05-02. اطلع عليه بتاريخ 2014-06-05.
We want something as usable for general programming as Python [...]
- ^ Yegulalp، Serdar (16 يناير 2017). "Nim language draws from best of Python, Rust, Go, and Lisp". InfoWorld. مؤرشف من الأصل في 2018-10-13.
Nim's syntax is strongly reminiscent of Python's, as it uses indented code blocks and some of the same syntax (such as the way if/elif/then/else blocks are constructed).
- ^ "An Interview with the Creator of Ruby". Linuxdevcenter.com. مؤرشف من الأصل في 2018-04-28. اطلع عليه بتاريخ 2012-12-03.
- ^ Lattner، Chris (3 يونيو 2014). "Chris Lattner's Homepage". Chris Lattner. مؤرشف من الأصل في 2019-12-23. اطلع عليه بتاريخ 2014-06-03.
I started work on the Swift Programming Language in July of 2010. I implemented much of the basic language structure, with only a few people knowing of its existence. A few other (amazing) people started contributing in earnest late in 2011, and it became a major focus for the Apple Developer Tools group in July 2013 [...] drawing ideas from Objective-C, Rust, Haskell, Ruby, Python, C#, CLU, and far too many others to list.
- ^ Kupries، Andreas؛ Fellows، Donal K. (14 سبتمبر 2000). "TIP #3: TIP Format". tcl.tk. Tcl Developer Xchange. مؤرشف من الأصل في 2017-07-13. اطلع عليه بتاريخ 2008-11-24.
- ^ Gustafsson، Per؛ Niskanen، Raimo (29 يناير 2007). "EEP 1: EEP Purpose and Guidelines". erlang.org. مؤرشف من الأصل في 2020-06-15. اطلع عليه بتاريخ 2011-04-19.
- ^ "Swift Evolution Process". Swift Programming Language Evolution repository on GitHub. 18 فبراير 2020. مؤرشف من الأصل في 2020-04-27. اطلع عليه بتاريخ 2020-04-27.
- ^ "writing warts". مؤرشف من الأصل في 17 فبراير 2020. اطلع عليه بتاريخ أكتوبر 2020.
{{استشهاد ويب}}
: تحقق من التاريخ في:|تاريخ الوصول=
(مساعدة) - ^ Guido van Rossum: Why explicit self has to stay نسخة محفوظة 25 ديسمبر 2019 على موقع واي باك مشين.
- ^ "PEP 3135 -- New Super". Python.org. مؤرشف من الأصل في 2020-06-19.
- ^ Rainer Fischbach: Wie Python arbeitet – Beschränkung aufs Wesentliche, heise.de, November 1999, abgerufen am 3. März 2017 نسخة محفوظة 16 نوفمبر 2018 على موقع واي باك مشين.
- ^ "Library and Extension FAQ — Python 3.7.0 documentation". Python.org. مؤرشف من الأصل في 2010-05-22.
- ^ Rossum، Guido van van. "It isn't Easy to Remove the GIL". Artima.com. مؤرشف من الأصل في 2019-06-06.
- ^ "Python–C". مؤرشف من الأصل في 2015-12-26. اطلع عليه بتاريخ 2015-12-25.
{{استشهاد ويب}}
: الوسيط غير المعروف|offline=
تم تجاهله يقترح استخدام|url-status=
(مساعدة) - ^ "Python–Perl". مؤرشف من الأصل في 2015-12-26. اطلع عليه بتاريخ 2015-12-25.
{{استشهاد ويب}}
: الوسيط غير المعروف|offline=
تم تجاهله يقترح استخدام|url-status=
(مساعدة) - ^ "Benchmark-Vergleich Python–PHP". مؤرشف من الأصل في 2015-12-26. اطلع عليه بتاريخ 2015-12-25.
{{استشهاد ويب}}
: الوسيط غير المعروف|offline=
تم تجاهله يقترح استخدام|url-status=
(مساعدة) - ^ "Benchmark-Vergleich Python–Dart". مؤرشف من الأصل في 2015-12-26. اطلع عليه بتاريخ 2015-12-25.
{{استشهاد ويب}}
: الوسيط غير المعروف|offline=
تم تجاهله يقترح استخدام|url-status=
(مساعدة) - ^ "Benchmark-Vergleich Python–Ruby". مؤرشف من الأصل في 2015-12-26. اطلع عليه بتاريخ 2015-12-25.
- ^ "Python Culture". 23 ديسمبر 2009. مؤرشف من الأصل في 2020-04-18.
- ^ "Python Patterns – An Optimization Anecdote". Python.org. مؤرشف من الأصل في 2020-05-14.
باللغة العربية
عدل- ^ ا ب ج د ه و ز ح "المرجع الشامل إلى تعلم لغة بايثون-أكادمية حسوب". مؤرشف من الأصل في 2020-07-03.
- ^ ا ب ج د ه و "الباحثون السوريون/بايثون". مؤرشف من الأصل في 2020-07-03.
- ^ "كيفية ترحيل شيفرة بايثون 2 إلى 3/أكادمية حسوب". مؤرشف من الأصل في 2020-07-05.
- ^ ا ب "معلومات حول بايثون في موقع كميوتر ود". computer.wd. مؤرشف من الأصل في 2020-07-03.
- ^ "كيفية إنشاء حلقات التكرار for". مؤرشف من الأصل في 2020-07-04.
- ^ ا "بديهيات بايثون على موقع أعجوبة". مؤرشف من الأصل في 2020-07-03.
- ^ "كيفية إجراء عملية حسابية ببايثون/أكادمية حسوب". مؤرشف من الأصل في 2020-07-03.
- ^ "وراثة الأصناف في بايثون/أكادمية حسوب". مؤرشف من الأصل في 2020-07-06.
- ^ "كيفية تكتب أول برنامج لك في بايثون/أكادمية حسوب". مؤرشف من الأصل في 2020-07-03.
- ^ "كيفية استخدام بوتل/أكادمية حسوب". مؤرشف من الأصل في 2020-07-04.
- ^ "استخدامات بايثون على موقع المطور". motwr.com. مؤرشف من الأصل في 2018-07-14.
مصادر
عدل- "Python for Artificial Intelligence". Wiki.python.org. 19 يوليو 2012. مؤرشف من الأصل في 2012-11-01. اطلع عليه بتاريخ 2012-12-03.
- Paine، Jocelyn، المحرر (أغسطس 2005). "AI in Python". AI Expert Newsletter. Amzi!. مؤرشف من الأصل في 2012-03-26. اطلع عليه بتاريخ 2012-02-11.
- "PyAIML 0.8.5 : Python Package Index". Pypi.python.org. مؤرشف من الأصل في 2017-07-14. اطلع عليه بتاريخ 2013-07-17.
- Russell، Stuart J.؛ Norvig، Peter (2009). Artificial Intelligence: A Modern Approach (ط. 3rd). Upper Saddle River, NJ: Prentice Hall. ISBN:978-0-13-604259-4.
{{استشهاد بكتاب}}
: الوسيط غير المعروف|lastauthoramp=
تم تجاهله يقترح استخدام|name-list-style=
(مساعدة)
قراءة معمقة
عدل- Downey، Allen B. (مايو 2012). Think Python: How to Think Like a Computer Scientist (ط. Version 1.6.6). ISBN:978-0-521-72596-5.
- Hamilton، Naomi (5 أغسطس 2008). "The A-Z of Programming Languages: Python". Computerworld. مؤرشف من الأصل في 29 ديسمبر 2008. اطلع عليه بتاريخ 31 مارس 2010.
- Lutz، Mark (2013). Learning Python (ط. 5th). O'Reilly Media. ISBN:978-0-596-15806-4.
- Pilgrim، Mark (2004). Dive Into Python. Apress. ISBN:978-1-59059-356-1.
- Pilgrim، Mark (2009). Dive Into Python 3. Apress. ISBN:978-1-4302-2415-0.
- Summerfield، Mark (2009). Programming in Python 3 (ط. 2nd). Addison-Wesley Professional. ISBN:978-0-321-68056-3.
دروس
عدلللمبتدئين
عدل- أمثلة بايثون (بالإنجليزية)
- دورات بايثون 2 و3 (بالألمانية)
- دورات أونلاينمن جامعة أنواترلو (بالألمانية/بالانكليزية/بالفرنسية)
- موقع مدرسة البرمجة العربية (بالعربية)
- موقع هرمش (بالعربية)
للمتقدمين
عدل- برمجة بايثون دوت نت: دروس بايثون لتحليل البيانات والذكاء الصنعي والواجهات الرسومية (بالإنكليزية)
- باي داتا: دروس بايثون لتعلم الألة وتحليل البيانات (بالانكليزية)
- بايثون الرائعة: قوائم متنوعة من المصادر تحتوي على مكتبات ودروس حسب الموضوع (بالانكليزية)
- أكاديمية حسوب (عربية)
للأطفال
عدل- ثعبان رانجلنج للأطفال - تعلم البرمجة مع بايثون من قبل من قبل جيسون ر. بريجز للأطفال من عمر الثامنة، رخصة ابداعية (الإنكليزية)
- الثعبان المشاكس -تعلم البرمجة للأطفال، للأطفال من عمر الثامنة، رخصة ابداعية (ألمانية)