fractions — Рациональные числа¶
Исходный код: Lib/fractions.py
Модуль fractions обеспечивает поддержку рациональной числовой арифметики.
Fraction сущность может быть построена из пары целых чисел, из другого рационального числа или из строки.
-
class
fractions.Fraction(numerator=0, denominator=1)¶ -
class
fractions.Fraction(other_fraction) -
class
fractions.Fraction(float) -
class
fractions.Fraction(decimal) -
class
fractions.Fraction(string) Первая версия требует, чтобы numerator и denominator были сущности
numbers.Rational, и возвращает новыйFractionсущность с значениеnumerator/denominator. Если denominator0, это поднимаетZeroDivisionError. Вторая версия требует, чтобы other_fraction был сущностьnumbers.Rationalи возвращалFractionсущность с тем же самым значение. Следующие две версии принимают илиfloatилиdecimal.Decimalсущность и возвращает aFractionсущность с точно тем же значение. Обратите внимание, что из-за обычных проблем с набором из двух предметов, с плавающей запятой (см. Арифметика с плавающей запятой: Проблемы и ограничения), аргументFraction(1.1)не точно равен 11/10, и таким образом,Fraction(1.1)делает не возвращаетFraction(11, 10), как можно было бы ожидать. (Но см. документацию для методаlimit_denominator()ниже.) последняя версия конструктора ожидает строка или Юникод сущность. Обычная форма для этой сущности:[sign] числитель ['/' знаменатель]
где необязательный
signможет быть «+» или «-«, аnumeratorиdenominator(если присутствуют) являются строки десятичных цифр. Кроме того, любой строка, представляющий конечную значение и принимаемый конструкторомfloat, также принимается конструкторомFraction. В любой форме входной строка может также иметь ведущее и/или конечное пробел. Вот несколько примеров:>>> from fractions import Fraction >>> Fraction(16, -10) Fraction(-8, 5) >>> Fraction(123) Fraction(123, 1) >>> Fraction() Fraction(0, 1) >>> Fraction('3/7') Fraction(3, 7) >>> Fraction(' -3/7 ') Fraction(-3, 7) >>> Fraction('1.414213 \t\n') Fraction(1414213, 1000000) >>> Fraction('-.125') Fraction(-1, 8) >>> Fraction('7e-6') Fraction(7, 1000000) >>> Fraction(2.25) Fraction(9, 4) >>> Fraction(1.1) Fraction(2476979795053773, 2251799813685248) >>> from decimal import Decimal >>> Fraction(Decimal('1.1')) Fraction(11, 10)
Класс
Fractionнаследует от абстрактного базового классаnumbers.Rationalи реализует все методы и операции из этого класса.Fractionсущности являются хэшируемыми и должны рассматриваться как неизменяемые. Кроме того,Fractionимеет следующие свойства и методы:Изменено в версии 3.2: Конструктор
Fractionтеперь принимаетfloatиdecimal.Decimalсущности.-
numerator¶ Числитель Fraction в самом низком члене.
-
denominator¶ Знаменатель Fraction в самом низком члене.
-
as_integer_ratio()¶ Возвращает кортеж из двух целых чисел, отношение которых равно доле и с положительным знаменателем.
Добавлено в версии 3.8.
-
from_float(flt)¶ Этот метод класса создает
Fraction, представляющий точную значение flt, которая должна бытьfloat. Остерегайтесь этого,Fraction.from_float(0.3)не тот же значение какFraction(3, 10).
-
from_decimal(dec)¶ Этот метод класса создает
Fraction, представляющий точную значение dec, которая должна бытьdecimal.Decimalсущность.Примечание
Начиная с Python 3.2, можно также построить
Fractionсущность непосредственно изdecimal.Decimalсущность.
-
limit_denominator(max_denominator=1000000)¶ Находит и возвращает ближайшую к
selfFraction, которая имеет знаменатель максимум max_denominator. Этот метод полезен для поиска рациональных приближений к заданному числу с плавающей запятой:>>> from fractions import Fraction >>> Fraction('3.1415926535897932').limit_denominator(1000) Fraction(355, 113)
или для восстановления рационального числа, представленного как float:
>>> from math import pi, cos >>> Fraction(cos(pi/3)) Fraction(4503599627370497, 9007199254740992) >>> Fraction(cos(pi/3)).limit_denominator() Fraction(1, 2) >>> Fraction(1.1).limit_denominator() Fraction(11, 10)
-
__floor__()¶ Возвращает наибольший
int<= self. Доступ к этому методу можно также получить с помощью функцииmath.floor():>>> from math import floor >>> floor(Fraction(355, 113)) 3
-
__ceil__()¶ Возвращает наименьшую
int>= self. Доступ к этому методу можно также получить с помощью функцииmath.ceil().
-
__round__()¶ -
__round__(ndigits) Первая версия возвращает ближайшую
intкself, округляя половину до чётной. Вторая версия округляетselfдо ближайшего кратногоFraction(1, 10**ndigits)(логически, еслиndigitsотрицательный), снова округляя половину в сторону четности. Доступ к этому методу можно также получить с помощью функцииround().
-
-
fractions.gcd(a, b)¶ Возвращает наибольший общий делитель целых чисел a и b. Если a или b ненулевое, то абсолютное значение
gcd(a, b)- наибольшее целое число, делящее и a, и b.gcd(a,b)имеет тот же знак, что и b, если b ненулевое; в противном случае он принимает знак a.gcd(0, 0)возвращает0.Не рекомендуется, начиная с версии 3.5: Используйте
math.gcd()вместо этого.
См.также
- Модуль
numbers - Абстрактные базовые классы, составляющие числовую башню.
