الفرق بين المراجعتين لصفحة: «Python/float»

من موسوعة حسوب
ط نقل Mohammed Taher صفحة Python/Types/float إلى Python/float
لا ملخص تعديل
سطر 39: سطر 39:
تعني <code>floatnumber</code> هنا رموز الأرقام العشرية في بايثون.
تعني <code>floatnumber</code> هنا رموز الأرقام العشرية في بايثون.


ليست السلسلة النصية حساسة لحالة الأحرف، لذا يمكن استخدام عبارات مثل <code>‎"inf"</code>‎ و <code>‎"INF"</code>‎ و <code>‎"INFINITY"‎</code> و <code>‎"iNfINity</code>"‎ لتمثيل القيمة الموجبة لما لا نهاية.
ليست السلسلة النصية حساسةً لحالة الأحرف، لذا يمكن استخدام عبارات مثل <code>‎"inf"</code>‎ و <code>‎"INF"</code>‎ و <code>‎"INFINITY"‎</code> و <code>‎"iNfINity</code>"‎ لتمثيل القيمة الموجبة لما لا نهاية.


إذا كان الوسيط عددًا صحيحًا integer أو عددًا عشريًا، تعيد الدالة عددًا عشريًا يحمل نفس القيمة (ضمن مقدار دقة الأعداد العشرية في بايثون). وإذا كانت قيمة الوسيط خارج نطاق الأعداد العشرية في اللغة فإنّها ستطلق خطأ من نوع <code>OverflowError</code>.
إذا كان الوسيط [[Python/int|عددًا صحيحًا]] أو عددًا عشريًا، فستعيد الدالة عددًا عشريًا يحمل نفس القيمة (ضمن مقدار دقة الأعداد العشرية في بايثون). وإذا كانت قيمة الوسيط خارج نطاق الأعداد العشرية في اللغة فإنّها ستطلق خطأ من نوع <code>OverflowError</code>.


في حال عدم وجود أي وسائط للدالة، فإنّها تعيد القيمة <code>0.0</code>.
في حال عدم وجود أي وسائط للدالة، فإنّها تعيد القيمة <code>0.0</code>.

مراجعة 06:03، 25 مارس 2018

الأعداد العشرية (ذات الفاصلة العائمة floating point) هي الأعداد التي تتضمن فاصلة عشرية أو علامة أسية:

>>> x = 2.5

>>> y = -1.609

>>> z = 3e4

>>> print(z)

30000.0

يمكن الحصول على معلومات حول دقّة الأعداد العشرية والتمثيل الداخلي لها في الحاسوب الذي يعمل عليه البرنامج عن طريق مكتبة sys.float_info:

>>> import sys

>>> sys.float_info

sys.float_info(max=1.7976931348623157e+308, max_exp=1024, max_10_exp=308, min=2.2250738585072014e-308, min_exp=-1021, min_10_exp=-307, dig=15, mant_dig=53, epsilon=2.220446049250313e-16, radix=2, rounds=1)

التحويل إلى الأعداد العشرية

تعيد الدالة float()‎ عددًا عشريًا من الرقم أو السلسلة النصية التي تمرّر إليها. إن كان الوسيط سلسلة نصية، فيجب أن يتضمن عددًا عشريًا، ويمكن أن يكون مسبوقًا بإشارتي '+' أو '-'، ولا تؤثر إشارة '+' على القيمة الناتجة. يمكن للوسيط الممرّر لهذه الدالة أن يكون سلسلة نصية تحمل قيمة NaN (اختصار not-a-number) أو موجب أو سالب ما لا نهاية infinity. وبصورة أدق يجب أن تطابق صيغة الوسيط الممرر إلى الدالة الصيغة التالية بعد حذف المسافات البيضاء التي تحيط بالوسيط:

sign ::= "+" | "-"

infinity ::= "Infinity" | "inf"

nan ::= "nan"

numeric_value ::= floatnumber | infinity | nan

numeric_string ::= [sign] numeric_value

تعني floatnumber هنا رموز الأرقام العشرية في بايثون.

ليست السلسلة النصية حساسةً لحالة الأحرف، لذا يمكن استخدام عبارات مثل ‎"inf"‎ و ‎"INF"‎ و ‎"INFINITY"‎ و ‎"iNfINity"‎ لتمثيل القيمة الموجبة لما لا نهاية.

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

في حال عدم وجود أي وسائط للدالة، فإنّها تعيد القيمة 0.0.

أمثلة

>>> float('+1.23')

1.23

>>> float(' -12345\n')

-12345.0

>>> float('1e-003')

0.001

>>> float('+1E6')

1000000.0

>>> float('-Infinity')

-inf

تغيير في الإصدار 3.6

أصبح بالإمكان تجميع الأعداد باستخدام الشرطة السفلية كما هو الحال مع رموز الأرقام المستخدمة في الشيفرة.

مصادر