اعداد و تبدیل نوع داده در برنامه نویسی پایتون
اعداد و تبدیل نوع داده در برنامه نویسی پایتون
در این درس از مجموعه آموزش برنامه نویسی سایت سورس باران، با اعداد و تبدیل نوع در برنامه نویسی پایتون، نحوه تبدیل از یک نوع داده به نوع دیگر و عملیات ریاضی پشتیبانی شده در پایتون، آشنا خواهید شد.
نوع داده عددی در برنامه نویسی پایتون
پایتون از اعداد صحیح، اعداد ممیز شناور و اعداد مختلط پشتیبانی می کند. آنها به عنوان کلاسهای int ،float و complex در پایتون تعریف می شوند.
پیشنهاد ویژه : پکیج آموزش پروژه محور پایتون
اعداد صحیح و ممیز شناور با وجود یا عدم وجود یک اعشار از یکدیگر تمیز داده می شوند. به عنوان مثال، 5 یک عدد صحیح است در حالی که 5.0 یک شماره ممیز شناور است.
اعداد مختلط به صورت x + yj نوشته می شوند، جایی که x قسمت حقیقی است و y قسمت موهومی است.
ما می توانیم از تابع ()type استفاده کنیم تا بدانیم متغیر متعلق به کدام کلاس است و از تابع ()isinstance برای بررسی اینکه متغیر متعلق به کلاس خاصی است یا خیر استفاده می شود.
بیایید به مثال زیر دقت کنیم:
1 2 3 4 5 6 7 8 9 10 |
a = 5 print(type(a)) print(type(5.0)) c = 5 + 3j print(c + 3) print(isinstance(c, complex)) |
خروجی
1 2 3 4 |
<class 'int'> <class 'float'> (8+3j) True |
در حالی که اعداد صحیح می توانند از هر طولی برخوردار باشند، اما یک عدد با ممیز شناور دقیقاً تا 15 رقم اعشار صحیح است.
اعدادی که هر روز با آنها سروکار داریم از سیستم اعداد اعداد دهدهی (پایه 10، Decimal) هستند. اما برنامه نویس ها باید با سیستم های عددی باینری (دودویی) (پایه 2)، هگزادسیمال یا شانزده شانزدهی (پایه 16) و اکتال یا هشت هشتی (پایه 8) کار کنند.
در پایتون می توانیم این اعداد را با قرار دادن پیشوند مناسب قبل از آن عدد نشان دهیم. در جدول زیر این پیشوندها را نوشته شده اند.
سیستم عددی |
پیشوند |
باینری (پایه 2) |
‘0b’ or ‘0B’ |
اکتال(پایه 8) |
‘0o’ or ‘0O’ |
هگزادسیمال (پایه 16) |
‘0x’ or ‘0X’ |
در اینجا چند مثال آورده شده است
1 2 3 4 5 6 7 8 |
# Output: 107 print(0b1101011) # Output: 253 (251 + 2) print(0xFB + 0b10) # Output: 13 print(0o15) |
خروجی
1 2 3 |
107 253 13 |
تبدیل نوع در پایتون
می توان یک نوع داده را به نوع دیگر تبدیل کنیم. این کار به coercion نیز معروف است.
عملیات هایی مانند جمع و تفریق بین اعداد صحیح و اعشاری، به طور ضمنی تبدیل نوع برای اعداد صحیح انجام می شود. به زیان ساده تر امکان جمع و تفریق عدد صحیح با ممیز شناور وحود ندارد و اگر این کار صورت بگیرید، عدد صحیح به ممیز شناور تبدیل می شود و سپس عملیات های جمع یا تفریق بر روی آن صورت می گیرد.
1 2 |
>>> 1 + 2.0 3.0 |
در بالا می توانیم ببینیم که 1 (عدد صحیح) با 2.0 (عدد شناور) جمع بسته می شود.
همچنین می توانیم از توابع داخلی مانند ()int() ،float و ()complex برای تبدیل صریح بین انواع استفاده کنیم. این توابع حتی می توانند از رشته ها تبدیل شوند.
1 2 3 4 5 6 7 8 |
>>> int(2.3) 2 >>> int(-2.8) -2 >>> float(5) 5.0 >>> complex('3+5j') (3+5j) |
هنگام تبدیل از عدد ممیز شناور به عدد صحیح، عدد کوتاه می شود (قسمت اعشاری حذف می شوند).
دهدهی در پایتون
کلاس شناور توکار پایتون، محاسبات فوقالعادهای ار انجام میدهد که ممکن است همه ما را متحیر کند. همه ما می دانیم که جمع 1.1 و 2.2 مساوی است با 3.3، اما به نظر می رسد پایتون با آن مخالف است.
1 2 |
>>> (1.1 + 2.2) == 3.3 False |
اما خب دلیل این کار چیست؟
به نظر می رسد که اعداد ممیز شناور در سخت افزار کامپیوتر به عنوان کسری دودویی پیاده سازی می شوند زیرا کامپیوتر فقط اعداد (0 و 1)باینری را می فهمد. به همین دلیل بیشتر کسرهای اعشاری نمی توانند به طور دقیق در رایانه ما ذخیره شوند.
به عنوان مثال: ما نمی توانیم کسر 1/3 را به عنوان یک عدد اعشاری نشان دهیم. زیرا …0.33333333 را نشان می دهد، که بی نهایت طولانی است، و ما فقط می توانیم آن را تقریبی کنیم.
به نظر می رسد که کسر اعشاری 0.1 منجر به کسری دودویی بی نهایت طولانی …0.00011001100110011001111 خواهد شد و رایانه ما فقط تعداد محدودی از آن را ذخیره می کند.
به همین دلیل ۰.۱ فقط تخمین زده شود بود اما هرگز برابر با عدد اصلی نیست. از این رو، این محدودیت سخت افزار رایانه ما است و نمی توان آن را به عنوان خطایی در پایتون دانست.
1 2 |
>>> 1.1 + 2.2 3.3000000000000003 |
برای غلبه بر این مسئله ، می توانیم از ماژول اعشاری (decimal) پایتون استفاده کنیم. در حالی که اعداد ممیز شناور دارای حداکثر 15 رقم اعشار هستند، ماژول اعشاری دارای دقت قابل تنظیم توسط کاربر است.
بیایید تفاوت را ببینیم:
1 2 3 4 5 |
import decimal print(0.1) print(decimal.Decimal(0.1)) |
خروجی
1 2 |
0.1 0.1000000000000000055511151231257827021181583404541015625 |
از این ماژول زمانی استفاده می شود که بخواهیم همانطور که در مدرسه آموخته ایم محاسبات اعشاری را انجام دهیم.
همچنین دقت عدد را حفظ می کند. می دانیم 25.50 کیلوگرم از 25.5 کیلوگرم دقیق تر است زیرا دارای دو رقم اعشار است.
1 2 3 4 5 |
from decimal import Decimal as D print(D('1.1') + D('2.2')) print(D('1.2') * D('2.50')) |
خروجی
1 2 |
3.3 3.000 |
به صفرهای انتهایی در مثال بالا توجه کنید.
ممکن است بپرسید، چرا Decimal را هر بار به جای ممیز شناور پیاده سازی نمی کنیم؟ دلیل اصلی کارایی است. عملیات ممیز شناور باید سریعتر از عملیات Decimal انجام شود.
چه زمانی از Decimal به جای ممیز شناور استفاده کنیم؟
ما به طور کلی در موارد زیر از Decimal استفاده می کنیم.
- وقتی ما در حال ساخت برنامه های مالی هستیم که نیاز به نمایش دقیق اعداد اعشاری دارند.
- وقتی می خواهیم سطح دقت مورد نیاز را کنترل کنیم.
- وقتی می خواهیم مفهوم اعشار قابل توجه را پیاده سازی کنیم.
کسرهای پایتون
پایتون از طریق ماژول fractions خود عملیاتی شامل اعداد کسری را ارائه می دهد.
کسر دارای یک صورت و مخرج است که هر دو عدد صحیح هستند. این ماژول از حساب عددی منطقی پشتیبانی می کند.
ما می توانیم اشیا را به روش های مختلف ایجاد کنیم. بیایید نگاهی به آنها بیندازیم.
1 2 3 4 5 6 7 |
import fractions print(fractions.Fraction(1.5)) print(fractions.Fraction(5)) print(fractions.Fraction(1,3)) |
خروجی
1 2 3 |
3/2 5 1/3 |
در حین ایجاد Faction از ممیز شناور، ممکن است نتایج غیرمعمولی بدست آوریم. این به دلیل نمایش نامناسب اعداد ممیز شناور دودویی است که قبلا درباره آن صحبت شده است
خوشبختانه، Faction به ما امکان می دهد که از رشته ها نیز کسر بسازیم. این گزینه ترجیحی هنگام استفاده از اعداد decimal است.
1 |
import fractions |
1 2 3 4 5 6 7 8 9 |
import fractions # As float # Output: 2476979795053773/2251799813685248 print(fractions.Fraction(1.1)) # As string # Output: 11/10 print(fractions.Fraction('1.1')) |
خروجی
1 2 |
2476979795053773/2251799813685248 11/10 |
این نوع داده از تمام عملیات های پایه ای ریاضی پشتیبانی می کند. در اینجا چند مثال آورده شده است.
1 2 3 4 5 6 7 8 9 |
from fractions import Fraction as F print(F(1, 3) + F(1, 3)) print(1 / F(5, 6)) print(F(-3, 10) > 0) print(F(-3, 10) < 0) |
خروجی
1 2 3 4 |
2/3 6/5 False True |
ریاضیات پایتون
پایتون ماژول هایی مانند math
و random
را برای انجام ریاضیات مختلف مانند مثلثات، لگاریتم ها، احتمالات و آمار و غیره ارائه می دهد.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
import math print(math.pi) print(math.cos(math.pi)) print(math.exp(10)) print(math.log10(1000)) print(math.sinh(1)) print(math.factorial(6)) |
خروجی
1 2 3 4 5 6 |
3.141592653589793 -1.0 22026.465794806718 3.0 1.1752011936438014 720 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
import random print(random.randrange(10, 20)) x = ['a', 'b', 'c', 'd', 'e'] # Get random choice print(random.choice(x)) # Shuffle x random.shuffle(x) # Print the shuffled x print(x) # Print random element print(random.random()) |
وقتی برنامه فوق را اجرا می کنیم، خروجی را به صورت زیر می گیریم. (ممکن است به دلیل رفتار تصادفی مقادیر متفاوت باشد)
1 2 3 4 |
18 e ['c', 'e', 'd', 'b', 'a'] 0.5682821194654443 |
لیست جلسات قبل آموزش برنامه نویسی پایتون
- آموزش نصب و اجرای برنامه نویسی پایتون
- کلیدواژه ها و شناسه های برنامه نویسی پایتون
- دستورات، تورفتگی ها و کامنت ها در برنامه نویسی پایتون
- متغیرها، ثابت ها و لیترال ها در برنامه نویسی پایتون
- انواع داده ها در برنامه نویسی پایتون
- تبدیل نوع در برنامه نویسی پایتون
- ورودی، خروجی و وارد کردن در برنامه نویسی پایتون
- عملگرها در برنامه نویسی پایتون
- نام و دامنه در برنامه نویسی پایتون
- دستور شرطی if…else در برنامه نویسی پایتون
- حلقه for در برنامه نویسی پایتون
- حلقه while در برنامه نویسی پایتون
- دستورات break و continue در برنامه نویسی پایتون
- دستور pass در برنامه نویسی پایتون
- توابع در برنامه نویسی پایتون
- آرگومان تابع در برنامه نویسی پایتون
- تابع بازگشتی در برنامه نویسی پایتون
- تابع بی نام/ تابع لامبدا در برنامه نویسی پایتون
- متغیرهای سراسری، محلی و غیر محلی در برنامه نویسی پایتون
- کلیدواژه global در برنامه نویسی پایتون
- ماژول های برنامه نویسی پایتون
- پکیج ها در برنامه نویسی پایتون
دیدگاه شما