如何在python中定义一个包含1000位数的十进制类?

时间:2013-11-14 14:53:22

标签: python class python-3.x python-3.3 bigdecimal

我需要一个包含1000个十进制数字的类来计算系列中的pi数字。花时间并不重要。如何定义__add__& ...这样做的功能? 例如,我需要一个值可以保存这个数字: 3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113

:))

使用decimal.Decimal的这个数字显示如下:

from decimal import Decimal as dc
>>> x=dc(3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113)
>>> x
Decimal('3.141592653589793115997963468544185161590576171875')

但我需要一个包含所有DIGITS的新类,我可以在其中使用添加,分割和...功能,如2 + 1和pi编号就是一个例子,我不需要计算pi编号I想要计算超大的十进制数!

4 个答案:

答案 0 :(得分:5)

您必须设置一个包含1000个十进制数字的上下文:

context = decimal.Context(prec=1000)
decimal.setcontext(context)

从现在起,计算将使用1000位精度。

示例:

>>> decimal.setcontext(decimal.Context(prec=1000))
>>> pi = decimal.Decimal('3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113')
>>> pi
Decimal('3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113')
>>> pi + 2
Decimal('5.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113')

请注意:

  • 您必须使用字符串初始化Decimal,因为如果使用float,解释器必须先截断它。 (我也相信只有最新版本的decimal接受float参数。在旧版本中,您必须使用Decimal.from_float代替。
  • 计算期间会保留小数位数。

您还可以通过localcontext contextmanager:

在本地使用上下文
context = decimal.Context(prec=1000)

with decimal.localcontext(context):
    # here decimal uses 1000 digits for computations
    pass

# here the default context is restored.

答案 1 :(得分:1)

您错误地使用Decimal初始化double对象,而x=dc(3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113) 无法代表您的大号。

所以不要说:

x=dc(3.1415926535897932384626433832795)

......其效果与:

完全相同
x=dc('3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113')

...从字符串初始化:

{{1}}

您将获得完全精确的预期结果。

答案 2 :(得分:0)

我的尝试。可能不是很好。

class pi:
    def __init__(self):
        self.pi_digits = ['1', '4', '1', '5', '9', '2', '6'] # pi = 3.1415926
    def __repr__(self):
        return '3.'+''.join(self.pi_digits)
    def add(self, digit):
        digit = str(digit)
        if digit.isdigit():
            self.pi_digits.append(digit)
        else:
            raise TypeError

my_pi = pi()
my_pi.add(3)
my_pi.add(5)
print (my_pi)

输出

3.141592635

PS - 这只是为了让您大致了解如何做事。

答案 3 :(得分:0)

此函数将根据分子(数字)和分母(deno)以及精度给出字符串值,该值可用于任何小数而不仅仅是pi。对于pi,你可以使用22/7和任何你想要的精度。

def pi_accur(numer,deno,precision):
    pi_holder=[]
    while (precision>=1):
        pi_holder.append(int(numer/deno))
        numer=10*(numer%deno)
        precision=precision-1

    new_val=str(pi_holder[0])+'.'
    for i in pi_holder[1:]:
        new_val=new_val+str(i)
    return new_val

>>> pi_accur(22,7,9)
     '3.14285714'

>>>pi_accur(22,7,15)
   '3.14285714285714'