زبان برنامه‌نویسی پایتون

از ویکی‌پدیا، دانشنامهٔ آزاد

(تغییر مسیر از پایتون (زبان))
پرش به: ناوبری, جستجو

پیتون یا پایتون[نیازمند منبع] یک زبان برنامه‌نویسی عام منظوره، سطح بالا، شیءگرا و تفسیری است که توسط گیدو ون روسوم (Guido van Rossum) در سال ۱۹۹۱ طراحی شد.

فلسفه‌ی ایجاد آن به دو هدف اصلی خوانایی بالای برنامه‌های نوشته شده و حاصل دهی با بازدهی بالای کارهای برنامه‌ نویس برمی‌گردد. کلمات کلیدی و اصلی این زبان به صورت حداقلی تهیه شده اند و در مقابل کتابخانه‌هایی که در اختیار کاربر است بسیار وسیع هستند. یک کار غیر معمول که در طراحی این زبان انجام گرفته استفاده از فاصله و جلوبردن متن برنامه برای مشخص کردن بلوک های مختلف کد است.

پایتون مدل های مختلف برنامه نویسی (از جمله شیء گرا و برنامه نویسی دستوری و تابع محور) را پشتیبانی می‌کند و برای مشخص کردن نوع متغییر ها از یک سامانه‌ی پویا استفاده می‌کند.

این زبان از زبان های برنامه نویسی تفسیری بوده و به صورت کامل یک زبان شی‌گرا است که در ویژگی‌ها با زبانهای تفسیری پرل، روبی، اسکیم، اسمال‌تاک و تی‌سی‌ال مشابهت دارد و از مدیریت خودکار حافظه استفاده می‌کند.

پایتون پروژه‌ای بازمتن توسعه یافته است و توسط بنیاد نرم‌افزار پایتون مدیریت می‌گردد. نسخهٔ کنونی (مارس ۲۰۰۸) این زبان ۲.6 است.همچنین نسخه ی آزمایشی 3.0 نیز موجود است

فهرست مندرجات

[ویرایش] تاریخچه

پایتون اواخر سال 1980 توسط Guido van Rossum در موسسه ملی تحقیقات ریاضی و رایانه ( CVVI ) در شهر هلند به عنوان جانشین زبان برنامه نویسی ای بی سی ایجاد شد که قابلیت پردازش استثنا را دارد. Van Rossum طراح اصلی پایتون است و نقش مداوم او در تصمیم گیری پیرامون اهداف پایتون ، باعث شد که انجمن پایتون به او لقب مدیر خیر اندیش زندگی ( BDFL ) را بدهد.

[ویرایش] چاپ اول

در سال 1991 van Rossum کدی با برچسب ورژن 0.9.0 را منتشر کرد. البته در این مرحله از پیشرفت کلاس هایی با خاصیت ارث بری ، پردازش استثنا ، توابع و نوع داده list , dict , str وجود داشت. همچنین در این نسخه ابتدایی یک سیستم ماژول با اقتباس از ماژول-3 وجود داشت. که van Rossum این ماژول را به عنوان "یکی از واحد های عمده برنامه نویسی پایتون " توصیف کرد. مدل استثناء پایتون نیز شباهت هایی به ماژول-3 داشت ، به علاوه شرط else . در سال 1994 اولین مجمع مباحثه پیرامون پایتون شکل گرفت که مرحله برجسته ای در پیشرفت کاربری پایتون بود.

[ویرایش] ورژن 1.0

پایتون در ژانویه 1994 به ورژن 1.0 رسید. خصوصیات عمده جدید این نسخه شامل ابزار های برنامه نویسی تابعی lambda , map , filter , reduce بود. ورژن پایتون 1.2 در سال 1995 ، زمانیکه van Rossum در CVVI بود ٬ بدست آمد. Van Rossum به فعالیت های خود روی پایتون در موسسه ملی تحقیقات و ابتکارات (CNRI) در رستون ادامه داد و در همانجا به چندین ورژن جدید دست یافت. در ورژن 1.4 پایتون به چندین ویژگی جدید رسید. جالب توجه در میان این ویژگی ها این بود که از آرگومان های کلیدی ماژول-3 الهام گرفته بود ( که همچنین مشابه آرگومان های کلیدی لیسپ بود ) و همین طور اعداد مختلط را پشتیبانی می‌کرد. در مدت فعالیت van Rossum در CNRI ، او ابتکار برنامه نویسی کامپیوتر برای هر کس ( CP4E ) را ایجاد کرد تا برنامه نویسی را در دسترس افراد بیشتری که اطلاعات پایه ای پیرامون زبان برنامه نویسی دارند ، قرار دهد. مشابه سواد انگلیسی و مهارت ریاضی که اغلب کارفرما ها دارا هستند. پایتون به دلیل تمرکزش بر روی پاکسازی علم نحو ، نقش مرکزی را ایفا کرد. این پروژه توسط دارپا سرمایه گذاری شد. از سال 2007 پروژه CP4E غیر فعال شد و زمانیکه پایتون تلاش کرد تا به آسانی قابل یاد گیری باشد و در صرف و نحو خیلی محرمانه نباشد ، به این نتیجه رسید که بدون برنامه نویس بودن چندان مهم نیست.

[ویرایش] باز بودن

در سال 2000 تیم توسعه دهنده پایتون به BeOpen.com منتقل شد و بدین صورت تیم کتابخانه باز پایتون شکل گرفت. به پیشنهاد CNRI ورژن 1.6 ساخته شد ، بدین ترتیب برنامه‌های تولید شده برای 1.6 و 2.0 اشتراک های قابل توجهی داشتند. فقط پایتون 2.0 توسط BeOpen.com طراحی شده بود. بعد از تولید پایتون 2.0 توسط BeOpen.com ، Guido van Rossum و دیگر توسعه دهندگان کتابخانه پایتون به ایجاد دیجیتال روی آوردند. تولید پایتون 1.6 شامل جواز جدید CNRI بود که به طور قابل توجهی طولانی تر از جواز CWI ( که برای تولیدات قبلی استفاده شده بود) بود. موسسه مستقل از نرم افزار توضیح داد که انتخاب شرط قانون با GNU GPL ناسازگار بود., BeOpen CNRI و FSF تغییراتی را در جواز پایتون مستقل از نرم افزار ایجاد کردند که با GPL سازگار باشد. پایتون 1.6.1 عمدتاً مشابه پایتون 1.6 است ، با کمی اشکال ، و با جواز سازگار با GPL .

[ویرایش] ورژن 2.0

پایتون 2.0 لیستی از ویژگی هایی را که از زبان های برنامه نویسی تابعی ستل و هاسکل اقتباس شده بود ، معرفی کرد. نحو پایتون برای این ساختار ( جدا از برتری هاسکل برای کاراکتر های نقطه گذاری و کلمات الفبا ) بسیار مشابه هاسکل بود. پایتون 2.0 همچنین یک سیستم بازیافت حافظه با قابلیت جمع آوری منابع معرفی کرد. پایتون 2.1 به پایتون 1.6.1 و 2.0 نزدیک بود. جواز آن به جواز مؤسسه نرم افزار پایتون تغییر نام یافت. همه کد ها ، اسناد و مشخصات اضافه شده را از زمان تولید الفبای پایتون 2.1 توسط مؤسسه نرم افزار پایتون ( PFS ) دارا شد. یک سازمان غیر انتفاعی در سال 2001 تشکیل شد که از مؤسسه نرم افزار آپاچی مدل گرفته بود. تولیدات شامل تغییراتی در خصوصیات زبان در پوشش حوزه‌های تو در تو بود ، مشابه دیگر زبان های حوزه ای ایستا. ( این خصوصیات دوباره از بین رفتند و به پایتون 2.2 منتقل نشدند.) یک تغییر بزرگ در پایتون 2.2 یکسان سازی انواع داده ای پایتون و کلاس ها به یک سلسله مراتب بود. این یکسان سازی اشیاء پایتون را کاملاً شیء گرا کرد.

[ویرایش] میراث جاوا

انتخاب نحو و ضمایم کتابخانه استاندارد پایتون شدیداً وابسته به بعضی موارد در جاوا بود : بسته logging در ورژن 2.3 ، تجزیه کننده SAX در ورژن 2.0 و ساختمان های نحو که در ورژن 2.4 اضافه شد.

[ویرایش] توسعه خصوصیات

یک طرح افزایش ( PEP ) در پایتون یکنواخت کردن اسنادی است که اطلاعات عمومی ای را که پایتون را شرح می‌دهند تولید می‌کنند ؛ شامل پیشنهادات ، توصیف ها و توضیح ها برای خصوصیات زبان . PEP در نظر داشت همانند روش های اولیه ، برای پیشنهاد خصوصیات جدید و نیز برای مستند سازی طرح های اساسی ، هر عامل بزرگ در پایتون را توضیح دهد. طرح های برجسته توسط van Rossum تجدید نظر شده و توضیح داده شدند.

[ویرایش] پایتون 3000

پایتون 3.0(که پایتون3000 ویاPy3k نیز خوانده می‌شود) به منظور شکستن backward compatibility یا به عبارتی قطع سازگاری با گذشته پایتون .2 و بهبود خطا ها و رخنه‌ها در ورژن 2. وهمچنین حذف روشهای قدیمی طراحی شد.به عبارتی دیگر لازم نیست که پایتون3 بتواند کدی که با پایتون .2 نوشته شده را تفسیر کند.که البته این مشکل توسط نرم افزار 2to3 حل می‌شود.

[ویرایش] فلسفه

پایتون 3.0 با همان فلسفه ورژن های قبل ، در حال توسعه یافتن است ، بنابراین هر منبعی در فلسفه پایتون ، در پایتون 3.0 به خوبی ظاهر خواهد شد. اگر چه ، همانطور که پایتون روش های جدید در برنامه ریزی را جمع آوری کرده ، پایتون 3.0 تأکید زیادی بر از بین بردن ساختار ها و ماژول های تکراری دارد: " باید یک – و ترجیحاًً فقط یک – روش بدیهی برای انجام آن وجود داشته باشد." با این وجود پایتون 3.0 به ساختار زبان چند نمونه ای ادامه خواهد داد. کد نویس ها همچنان اختیارات شیء گرایی ، برنامه نویسی ساخت یافته ، برنامه نویسی تابعی و دیگر نمونه‌ها را دارند ، اما در انتخاب های وسیع ، جزئیات در پایتون 3.0 آشکار تر از پایتون سری 2.x هستند.

[ویرایش] سازگاری و همزمانی

اولین کاندید پایتون 3.0 در 17سپتامبر 2008 منتشر شد. پایتون سری 2.x و 3.x به طور موازی با هم وجود خواهند داشت ، جایی که سری 2.x سازگاری بیشتری دارد ، به جای سری 3.x مورد استفاده قرار خواهد گرفت. PEP 3000 اطلاعات بیشتری را در مورد فهرست نشریات دارا ست. پایتون 3.0 سازگاری قبل را نقض خواهد کرد. الزامی ندارد که کد هایی که با پایتون 2.x اجرا می‌شوند ، برای پایتون 3.0 بدون تغییر اجرا شوند. چون تغییرات اساسی بین این دو ورژن وجود دارد مثل اختلاف در حالت پرینت ( بنابراین هر استفاده از پرینت به عنوان توضیح باعث شکست برنامه می‌شود.) نوع پویای پایتون با طرح های تغییر معنای روش های خاص دیکشنری ترکیب می‌شود ، به عنوان مثال ، انتقال مکانیکی بی نقص از پایتون 2.x به پایتون 3.0 را بسیار دشوار می‌کند. اگرچه ابزاری به نام " 2to3 " بسیاری از این وظایف انتقال را انجام می‌دهد ، اما باید توجه داشت که استفاده از توضیحات یا اخطار ها با ابهام همراه است. البته در یک مرحله از الفبا ، 2to3 انتقال را حقیقتاً کامل انجام می‌دهد. PEP 3000 پیشنهاد می‌کند که یک منبع نگه داشته شود (برای سری 2.x) ، و نسخه ای بر مبنای پایتون 3.0 با استفاده از 2to3 تولید شود. کد های نتیجه شده نباید تصحیح شوند ، مگر اینکه کدی طولانی تر از محدوده سری 2.x باشد. پایتون 2.6 شامل خصوصیات سازگاری مستقیم است ، به طوریکه یک روش اخطار ( warning ) به صورت خودکار به مسائل انتقال هشدار می‌دهد. هشدار ها باید برای تشخیص خطا گزارش داده شوند ، مشابه خصوصیات ورژن های قبلی پایتون. ( برای اطلاعات بیشتر به PEP 361 رجوع کنید. )

[ویرایش] خصوصیات

فهرست برخی از تغییرات عمده پایتون 3.0 :

  • تغییر پرینت چون یک تابع غیر قابل انتقال است نه یک توضیح. این باعث می‌شود که تغییر یک ماژول برای استفاده از یک تابع پرینت متفاوت ، آسان باشد و بنابراین ایجاد نحو منظم تر می‌شود. در پایتون 2.6 این امکان با تایپ کردن from – future – import print – function فراهم شد.
  • اضافه شدن حمایت از یادآوری تابع انتخابی که می‌تواند برای معرفی تایپ خصوصی یا اهداف دیگر استفاده شود.
  • یکسان کردن تایپ str/Unicode ، به نمایندگی از یک متن ، و معرفی یک تایپ byte تغییر ناپذیر ؛ با یک تایپ مطابق با bytearray تغییر پذیر ، که هر دو آرایه از بایت را ارائه می‌کنند.
  • از بین بردن خصوصیات سازگاری معکوس ، شامل کلاس های به فرم قبل ، قسمت کردن اعداد صحیح ، استثناء های رشته ای ، و گزارش های نسبتاً نا آشکار.

[ویرایش] کاربرد

سازمان های بزرگی که امکان استفاده از پایتون را فراهم می‌کنند ، شامل گوگل ، یاهو ، سرن و ناسا هستند. ITA نیز از پایتون برای بعضی از اجزای خود استفاده می‌کند.

[ویرایش] امنیت اطلاعات

پایتون همچنین استفاده وسیعی از صنعت ایمنی اطلاعات می‌کند. مثلاً در چندین ابزار پیشنهاد شده توسط تأمین امنیت و امنیت مرکزی و اسکنر امنیت کاربردی وب واپیتی. پایتون معمولاً در توسعه کاربرد مورد استفاده قرار می‌گیرد.

[ویرایش] جاسازی

پایتون با موفقیت در تعدادی از تولیدات نرم افزاری مثل زبان فایل آغاز گر تعبیه شده است.پایتون معمولاً در بسته‌های انیمیشن 3D استفاده می‌شود ، مانند Houdini , Maya , Softimage XSI , TrueSpace , Poser , Modo , Nuke , Blender . GIMP , Krita , Inkcape , Scribus , Paint Shop Pro ESRI هم اکنون در حال ترقی دادن پایتون به عنوان بهترین انتخاب برای نوشتن فایل آغازگر در ArcGIS است. همچنین در بازی ها استفاده می‌شود ، مانند Civilization IV و Mount&Blade به عنوان زبان کنترل برای نمایش و عکس العمل حوادث.

[ویرایش] مقبولیت

در بسیاری از سیستم های عملیاتی ، پایتون یک جزء استاندارد است ؛ چون با بیشتر بخش های لینوکس انتقال داده می‌شود، با NetBSD و OpenBSD وRed Hat Linux .Mac OS X و Fedora هر دو از نصب کنده پایتونی استفاده می‌کنند. لینوکس Gentoo از پایتون در سیستم مدیریت بسته ، حمل و ابزار های دستیابی خود استفاده می‌کند. Pardus از آن برای مدیریت و در طول راه اندازی سیستم استفاده می‌کند.

[ویرایش] صرف و نحو

پایتون در نظر دارد که زبانی بسیار قابل خواندن باشد. بنابراین به سمت یک طرح بندی ویژوال بدون پارازیت می‌رود ، و اغلب از کلمات کلیدی انگلیسی استفاده می‌کند ، در صورتیکه دیگر زبان ها از نقطه گذاری استفاده می‌کنند. پایتون نسبت به زبان های ساخت یافته سنتی ، مثل C و پاسکال ، نیاز به تکیه کلام های کمتر و همچنین استثناء های نحوی و موارد خاص کمتری دارد.

Syntax-highlighted Python 2.x code.
مقالهٔ اصلی: Python syntax and semantics

[ویرایش] ایجاد فضای خالی

پایتون از فضاهای خالی بیشتر از آکولاد یا کلمات کلیدی برای تعیین بلوک های حالت استفاده می‌کند ( ویژگی ای که به نام قانون off-side نیز شناخته می‌شود.)

[ویرایش] شرط ها و روند کنترل

شرط های پایتون شامل:

  • شرط if ، که یک بلوک کد ، تا else و elif را اجرا می‌کند. (یک اختصار از else-if )
  • شرط for ، که روی یک شیء تکرار شدنی تکرار می‌شود ، به هر متغیر محلی مقدار داده می‌شود برای استفاده توسط بلوک مربوطه.
  • شرط class ، که یک بلوک کد را اجرا می‌کند و فضاهای محلی آن را به یک کلاس ملحق می‌کند ، برای استفاده در برنامه نویسی شیء گرا.
  • شرط def ، که یک تابع را تعریف می‌کند.
  • شرط with ، که یک بلوک کد را به یک مدیر متن ضمیمه می‌کند. ( به عنوان مثال ، اندوختن یک قفل قبل از اجرای بلوک کد و آزاد کردن قفل بعد از اجرا.)

هر شرطی برای خود قواعد معنایی خاصی دارد: به عنوان مثال ، شرط def ، بر خلاف دیگر شرط ها بلوک خود را فوراً اجرا نمی‌کند.

سی پایتون استمرار را پشتیبانی نمی‌کند ، و مطابق نظر Guido van Rossum هرگز نخواهد کرد. در ورژن های قبلی مولد تکرار کند بود چون اطلاعات تنها در یک جهت از مولد عبور می‌کردند.

[ویرایش] روش ها

روش ها در اشیاء پایتون ، ملحق کردن توابع به اشیاء کلاس است ؛ با نحو (instance.method(argument برای روش ها و توابع نرمال ،و(Class.method (instance,argument . روش های پایتون ، یک پارامتر self آشکار برای دستیابی به داده‌های instance دارند ، در برابر پارامتر self غیر آشکار در برخی زبان های برنامه نویسی شیء گرا ( مانند جاوا ، C++ ، یا روبی )

[ویرایش] نوع دهی

پایتون از اشیاء تایپ شده و در مقابل نام متغیر های غیر تایپ استفاده می‌کند. محدودیت تایپ در زمان کامپایل چک نمی‌شود ؛ بنابراین عمل گر های روی یک شیء ممکن است شکست بخورند ، به این مفهوم که شیء داده شده از یک تایپ مناسب نیست. با اینکه اجباری در تایپ دهی ایستا نیست ، پایتون شدیداً تایپ دهی شده ، و عمل گر های نامناسب را نهی می‌کند. ( مثل مقدار دهی یک رشته با یک عدد )

تایپ توصیف مثال نحو
str یک رشته غیر قابل تغییر از کاراکتر ها 'Wikipedia'
"Wikipedia"
list تغییر پذیر ، می‌تواند تایپ های مختلف را دارا باشد. [4.0, 'string', True]
tuple تغییر ناپذیر ، می‌تواند تایپ های مختلف را دارا باشد. (4.0, 'string', True)
set, frozenset نامرتب ، هیچ نسخه دومی را دارا نیست. set([4.0, 'string', True])
{4.0, 'string', True}
frozenset([4.0, 'string', True])
dict گروهی از کلید ها با جفت عددی {'key1': 1.0, 'key2': False}
int یک عدد با دقت ثابت

(وقتی ذخیره کردن یک عدد صحیح سر ریز داشته باشد ، به یک دقت نامحدود Long بسط خواهد یافت.)

42
float یک عدد حقیقی 3.1415927
complex یک عدد مختلط با عدد حقیقی و قسمت موهومی 3+2j
bool عدد درستی True
False

پایتون همچنین به برنامه نویس ها اجازه می‌دهد که تایپ دلخواه خود را تعریف کنند. این کار با استفاده از کلاس ها امکان پذیر است ، و اغلب برای شیء گرایی در برنامه نویسی استفاده می‌شود. نمونه‌های جدید از کلاس ها با صدا زدن کلاس ساخته می‌شوند ، و کلاس ها خودشان نمونه‌هایی از کلاس type هستند ( خودش یک نمونه از خودش است).

[ویرایش] پیاده سازی

مسیر اصلی پیاده سازی پایتون ، که با عنوان سی پایتون نیز شناخته می‌شود ، در نشست C در استاندارد C89 نوشته شد. سی پایتون برنامه‌های پایتون را به کد بایت تبدیل می‌کند ، که سپس توسط ماشین مجازی اجرا می‌شود. سی پایتون با یک کتابخانه استاندارد بزرگ که به صورت مخلوطی از C و پایتون نوشته شده ، توزیع شده است. سی پایتون در ورژن های مختلف برای پایگاه‌های زیادی کار می‌کند ، شامل مایکروسافت ویندوز و بیشتر سیستم های پیشرفته یونیکس. استفاده و توسعه آن روی پایگاه‌های محرمانه مانند Amoeba ، در کنار پایگاه‌های متداول مانند یونیکس یا مکینتاش ، به طور عمده در این نظر کمک شده است.

پایتون بدون پشته ، انشعابی از سی پایتون است که ریز برنامه‌ها را اجرا می‌کند ؛ و از پشته حافظه استفاده نمی‌کند. سی پایتون از GIL استفاده می‌کند تا وقتی برنامه پایتون بدون پشته ، وابسته به OS است و می‌تواند به صورت همزمان اجرا شود ، در هر لحظه فقط به یک زیر برنامه اجازه اجرا داده شود. پایتون برای استفاده در میکرو کنترلر ها یا وظایف محدود دیگر پایگاه‌های مرجع ، متناسب تر است. پیش بینی می‌شود که پایتون بدون پشته بتواند تقریباً روی همان پایگاهی که سی پایتون اجرا می‌شود ، اجرا شود.

جی تون برنامه‌های پایتون را به کد بایت جاوا کامپایل می‌کند ، که بدین ترتیب می‌تواند با هر ماشین مجازی جاوا اجرا شود. و همچنین این امکان فراهم می‌شود که توابع کتابخانه ای کلاس جاوا از برنامه پایتون به کار گرفته شود. آی رون پایتون از همین شیوه برای اجرای برنامه‌های پایتون روی زبان .NET استفاده می‌کند.

پای پای یک پیاده سازی تجربی از پایتون است که می‌تواند چندین تایپ از کد بایت را تولید نماید.

چندین برنامه در بسته مفسر پایتون با برنامه‌های کاربردی ( یا آغازگر ) وجود دارد که مستقلاً اجرا می‌شوند مانند یونیکس ، لینوکس ، ویندوز ، AmigaOS 4 یا Mac OS X . بسیاری از کتابخانه‌های سه قسمتی (و حتی بعضی از یک قسمتی ها) فقط روی ویندوز ، لینوکس ، BSD و Mac OS X موجود هستند.

در نوکیا 2005 یک مفسر پایتون برای موبایل های سری 60 با نام PyS60 تولید شد که شامل بسیاری از ماژول ها از سی پایتون بود ، و همچنین برخی ماژول های اضافه شده برای یکپارچه شدن با سیستم عامل. این پروژه به منظور اجرا روی همه پایگاه‌های مختلف S60 ، به روز نگاه داشته می‌شود.

همچنین مفسری به نام پایتون سی ای برای ابزار ویندوز CE ( شامل بسته PC ) وجود دارد. که در آن ابزار هایی برای اجرای آسان و توسعه GUI اضافه شده است. اطلاعات بیشتر را می‌توانید روی وب‌گاه PythonCE بیابید.

پایتون چینی زبان برنامه نویسی پایتونی است که از لغت نامه زبان چینی استفاده می‌کند. در کنار کلمات رزرو شده و نام متغیر ها ، بیشتر عمل گر های تایپ داده ، در چینی می‌توانند به خوبی کد دهی شوند.

[ویرایش] تفسیر معنایی

بیشتر پیاده سازی های پایتون ( شامل سی پایتون ، اولین پیاده سازی ) می‌توانند به عنوان یک مفسر خط فرمان عمل کنند ، برای زمانی که کاربر رشته شرط را وارد می‌کند و فوراً نتیجه را می پذیرد. خلاصه پایتون به عنوان یک برنامه واسط عمل می‌کند. وقتی صرف دیگر شیوه‌های اجرا ( کامپایل کد بایت یا کامپایل کد محلی ) به صورت یک رشته صرف ذخیره می‌شود ، یک افزایش سرعت در هزینه‌های متقابل به وجود می‌آید ، بنابراین آنها معمولاً فقط خارج از مفسر خط فرمان استفاده می‌شوند. ( وقتی یک ماژول وارد می‌شود. )

برنامه‌های واسط دیگر ، امکانات تحت آن را در مفسر بیسیک افزایش می‌دهند ، شامل IDLE و I Python . وقتی عموماً از برنامه واسط پایتون پیروی می‌شود ، خصوصیاتی مشابه تکمیل خودکار ، نگه داشتن زمان اجرای برنامه ، و نشان دادن صرف پیاده سازی می‌شود.

برخی از پیاده سازی ها نه تنها به صورت کد بایت می‌توانند کامپایل شوند ، بلکه می‌توانند کد پایتون را به کد ماشین تبدیل کنند. تا کنون ، این عمل فقط برای زیر مجموعه‌های انحصاری پایتون انجام شده است. پای پای این روش را پذیرفته و ورژن های قابل کامپایل انحصاری پایتون را RPython نامید.

Psyco یک کامپایلر اختصاصی در زمان است که کد بایت را به کد ماشین ، در زمان اجرا تبدیل می‌کند. کد تولید شده ، اختصاصی برای تایپ های داده خاصی است و از کد های استاندارد پایتون سریع تر است. Psyco با همه کد های پایتون سازگار است ، نه فقط یک زیر مجموعه.

[ویرایش] کتابخانه استاندارد

پایتون یک کتابخانه استاندارد بزرگ دارد ، که از آن به عنوان یکی از بزرگ ترین توانایی های پایتون یاد می‌شود ، مشروط به اینکه ابزار های از پیش نوشته شده ، با بسیاری از وظایف سازگار باشد. ماژول های کتابخانه استاندارد می‌توانند به شیوه ماژول های نوشته شده در سی یا پایتون آرگومان دهی شوند. اخیراً کتابخانه‌های C++ به یک کتابخانه به نام Boost.Python رشد یافته است ، برای ایجاد قابلیت همکاری بین C++ و پایتون. به دلیل تنوع گسترده در ابزار های تولید شده توسط کتابخانه استاندارد ، این کتابخانه با توانایی استفاده یک زبان سطح پایین ترکیب شده ، مثل C و C++ ، که البته به عنوان واسط بین کتابخانه‌های دیگر است ، پایتون می‌تواند یک واسط قوی بین زبان ها و ابزار ها باشد.

کتابخانه استاندارد با تعداد زیاد فرمت ها و پروتکل هایی که حمایت می‌کند (مانند MIME و HTTP ) ، خصوصاً برای نوشتن علائم اینترنت مناسب است. ماژول ها برای ایجاد واسط کاربر گرافیکی ، به پایگاه داده مربوطه متصل می‌شود ، محاسبات را با دقت دلخواه دسیمال انجام می‌دهد ، و عبارت های منظم را دستکاری می‌کند. پایتون همچنین یک واحد تست مدیریت پایگاه داده برای تست کردن رشته‌ها دارد.

بعضی از قسمت های کتابخانه استاندارد با مشخصات پوشانده شده ، اما اکثریت ماژول ها اینگونه نیستند. آنها از طریق کدها ، اسناد داخلی ، و دنباله تست شان ( اگر موجود باشد ) تعیین می‌شوند. اگر چه ، به دلیل اینکه اکثر کتابخانه‌های استاندارد ، کد پایتون مربوط به پایگاه را دارند ، فقط ماژول های اندکی هستند که باید تغییر داده شوند یا مجدّداً با یک پیاده سازی دیگر نوشته شوند.

[ویرایش] فلسفه برنامه نویسی

پایتون یک زبان برنامه نویسی چند الگویی است. به این معنی که بیشتر برنامه نویس های قدرتمند برای وقتی یک مدل برنامه نویسی را انتخاب می‌کنند ، مجاز به چندین مدل هستند: شیء گرایی و برنامه نویسی ساخت یافته کاملاً تحت پوشش هستند ، و تعدادی از خصوصیات زبان های برنامه نویسی هستند که برنامه نویسی تابعی و ظاهر سازی را پشتیبانی می‌کنند. پایتون از تایپ پویا و یک ترکیبی از شمارش مرجع و یک حلقه کشف و بازیافت قسمت های هدر رفته حافظه برای مدیریت حافظه ، استفاده می‌کند. یک ویژگی مهم پایتون تحلیل نام پویا است ، که روش ها و نام متغیر ها را در طول اجرای برنامه به هم ملحق می‌کند.

هدف دیگر طراحی زبان آسان کردن توسعه پذیری است. ماژول هایی که تازه ساخته شده اند ، به سادگی در C و C++ نوشته می‌شوند. پایتون همچنین می‌تواند به عنوان زبان توسعه برای ماژول ها و کاربرد های موجود که به برنامه واسط قابل برنامه ریزی نیاز دارد ، استفاده شود. این طرح که یک زبان هسته کوچک با یک کتابخانه استاندارد بزرگ و یک مفسر آسان توسعه پذیر همراه باشد ، توسط Van Rossum بیان شد.

طرح پایتون به پشتیبانی محدود برای برنامه نویسی تابعی به شیوه لیسپ ، ارائه شد. اگر چه ، تشابه‌های عمده ای بین پایتون و زبان خانواده لیسپ وجود دارد. این کتابخانه دو ماژول دارد ( تکرار و تابعی ) که ابزار های تابعی را با اقتباس از هاسکل و ام ال استاندارد پیاده سازی می‌کند.

وقتی انتخاب هایی در روش شناسی کد ها ارائه شد ، پایتون نحو های فراوان را کنار گذاشت. همچنان که با پرل ، توسعه دهندگان پایتون فوراً یک فرهنگ یا ایدئولوژی را بر مبنای آنچه از یک زبان می خواهند ، ترقی دادند ، ساختار زبان ها زیبا ، آشکار و ساده شد. Alex Martelli این مطلب را در کتاب خود قرار داد: “برای توضیح برخی مسائل ، در فرهنگ پایتون تعریفی مطرح نشده است." پایتون روش پرل را (بیش از یک روش در انجام آن وجود دارد) در طراحی زبان در حمایت از " باید یک راه – و ترجیحاً فقط یک راه – آشکار برای انجام آن وجود دارد." رد کرد.

پایتون از بهینه سازی بی موقع اجتناب کرد ، و بعلاوه به هم جور کردن قسمت های غیر ضروری سی پایتون را که افزایش سرعت نهایی در هزینه را ارائه می‌کرد ، رد کرد. آن گاهی اوقات با نام ' slow ' شناخته می‌شود. اگر چه ، بیشتر مسائل چندان بحرانی نیستند ، و همین طور سرعت سخت افزار کامپیوتر با سرعت نمائی رو به رشد است. وقتی سرعت یک مسأله باشد ، برنامه نویسان پایتون بیشتر تلاش می‌کنند تا عملیات محدود را با بهبود الگوریتم یا تغییر ساختار داده ، بهینه کنند.

[ویرایش] واژه تراشی

یک واژه تراشی رایج در انجمن پایتون ، در pythonic است ، که می‌تواند محدوده وسیع معنایی وابسته به استیل برنامه داشته باشد. در مقابل یک کد unpythonic تلاش می‌کند تا یک کد C++ را در پایتون بنویسد.

[ویرایش] برنامه‌های نوشته شده با پایتون

  • بیتتورنت (BitTorrent) : نرم افزاری برای جستجوی فایل‌های به اشتراک گذاشته شده(p۲p) و ...
  • بلندر (‌Blender) : یک نرم افزار ۳ بعدی و اپن سورس بسیار معروف
  • چندلر (Chandler) : مدیر اطلاعات شخصی شامل تقویم ، میل ، کار‌های روزلنه ، یادداشت‌ها و ...
  • Civilization IV : یک گیم کامپیوتری بر مبنای پایتون که از boost.python استفاده می‌کند
  • میلمن (Mailman) : یکی از معروفترین نرم افزار‌های مرتبط با ایمیل
  • کمبیلوKombilo : مدیر پایگاه داده و مرورگرگیم‌های go
  • موین‌موین (MoinMoin) : یکی از قدرتمندترین و معروفتریم ویکی‌های موجود
  • پلون (Plone) : یک ابزار مدیریتی محتوایی اپن سورس ، قدرتمند و کاربر پسند
  • پورتاژ (Portage) : قلب توزیع جنتو . یک مدیر بستهای سیستم لینوکس
  • زوپ (zope) : یک پلاتفورم شی گرای مبتنی بر وب . زوپ شامل یک سرور نرم افزار به همراه پایگاه داده شی گرا و یک رابط مدیریتی درونی مبتنی بر وب می‌باشد
  • اس پی ای (SPE) : یک IDE رایگان ، اپن سورس برای سیستم عامل‌های ویندوز ، لینوکس ، مک که از wxGlade(طراحی رابط کاربر),PyChecker (دکتر کد) Blender(۳D) پشتیبانی می‌کند .

[ویرایش] پیوند به بیرون