當前位置: 首頁>>代碼示例>>Python>>正文


Python decimal.ROUND_UP屬性代碼示例

本文整理匯總了Python中decimal.ROUND_UP屬性的典型用法代碼示例。如果您正苦於以下問題:Python decimal.ROUND_UP屬性的具體用法?Python decimal.ROUND_UP怎麽用?Python decimal.ROUND_UP使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在decimal的用法示例。


在下文中一共展示了decimal.ROUND_UP屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def get(self):
        setting = db_session.query(DBSetting).get('credit-payoff')
        if setting is None:
            pymt_settings_json = json.dumps({'increases': [], 'onetimes': []})
        else:
            pymt_settings_json = setting.value
        pymt_settings_kwargs = self._payment_settings_dict(pymt_settings_json)
        try:
            ih = InterestHelper(db_session, **pymt_settings_kwargs)
            mps = sum(ih.min_payments.values())
            payoffs = self._payoffs_list(ih)
        except NoInterestChargedError as ex:
            resp = render_template(
                'credit-payoffs-no-interest-error.html',
                acct_name=ex.account.name,
                acct_id=ex.account.id
            )
            return resp, 500
        return render_template(
            'credit-payoffs.html',
            monthly_pymt_sum=mps.quantize(Decimal('.01'), rounding=ROUND_UP),
            payoffs=payoffs,
            pymt_settings_json=pymt_settings_json
        ) 
開發者ID:jantman,項目名稱:biweeklybudget,代碼行數:26,代碼來源:credit_payoffs.py

示例2: calculate_price

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def calculate_price(base_quantity, quote_quantity, base_divisibility, quote_divisibility, order_type=None):
    if not base_divisibility:
        base_quantity *= config.UNIT
    if not quote_divisibility:
        quote_quantity *= config.UNIT

    try:
        if order_type == 'BUY':
            decimal.setcontext(decimal.Context(prec=8, rounding=decimal.ROUND_DOWN))
        elif order_type == 'SELL':
            decimal.setcontext(decimal.Context(prec=8, rounding=decimal.ROUND_UP))

        price = format(D(quote_quantity) / D(base_quantity), '.8f')

        decimal.setcontext(decimal.Context(prec=8, rounding=decimal.ROUND_HALF_EVEN))
        return price

    except Exception as e:
        logging.exception(e)
        decimal.setcontext(decimal.Context(prec=8, rounding=decimal.ROUND_HALF_EVEN))
        raise(e) 
開發者ID:CounterpartyXCP,項目名稱:counterblock,代碼行數:23,代碼來源:dex.py

示例3: float2dec

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def float2dec(ft, decimal_digits):
    """
    Convert float (or int) to Decimal (rounding up) with the
    requested number of decimal digits.

    Arguments:
        ft (float, int): Number to convert
        decimal (int): Number of digits after decimal point

    Return:
        Decimal: Number converted to decima
    """
    with decimal.localcontext() as ctx:
        ctx.rounding = decimal.ROUND_UP
        places = decimal.Decimal(10)**(-decimal_digits)
        return decimal.Decimal.from_float(float(ft)).quantize(places)


# Sorting algos for rectangle lists 
開發者ID:secnot,項目名稱:rectpack,代碼行數:21,代碼來源:packer.py

示例4: _get_depreciation_stop_date

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def _get_depreciation_stop_date(self, cr, uid, asset, depreciation_start_date, lost_year, context=None):
        if asset.method_time == 'year':
            depreciation_stop_date = depreciation_start_date + relativedelta(years=asset.method_number, days=-1)
        elif asset.method_time == 'number':
            if asset.method_period == 'month':
                depreciation_stop_date = depreciation_start_date + relativedelta(months=asset.method_number, days=-1)
            elif asset.method_period == 'quarter':
                depreciation_stop_date = depreciation_start_date + relativedelta(months=asset.method_number * 3, days=-1)
            elif asset.method_period == 'year':
                depreciation_stop_date = depreciation_start_date + relativedelta(years=asset.method_number, days=-1)
        elif asset.method_time == 'end':
            depreciation_stop_date = datetime.strptime(asset.method_end, '%Y-%m-%d')
        elif asset.method_time == 'percent':
            if asset.method_period == 'month':
                depreciation_stop_date = depreciation_start_date + relativedelta(
                    months=int(Decimal(str(100 / asset.method_number_percent)).quantize(Decimal('1'), rounding=ROUND_UP)), days=-1)
            elif asset.method_period == 'quarter':
                depreciation_stop_date = depreciation_start_date + relativedelta(
                    months=int(Decimal(str(100 / asset.method_number_percent * 3)).quantize(Decimal('1'), rounding=ROUND_UP)), days=-1)
            elif asset.method_period == 'year':
                depreciation_stop_date = depreciation_start_date + relativedelta(
                    years=int(Decimal(str(100 / asset.method_number_percent)).quantize(Decimal('1'), rounding=ROUND_UP)) + lost_year, days=-1)
        return depreciation_stop_date 
開發者ID:iw3hxn,項目名稱:LibrERP,代碼行數:25,代碼來源:account_asset.py

示例5: roundup

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def roundup(number, num_digits = 0): # Excel reference: https://support.office.com/en-us/article/ROUNDUP-function-f8bc9b23-e795-47db-8703-db171d0c42a7

    if not is_number(number):
        return ExcelError('#VALUE!', '%s is not a number' % str(number))
    if not is_number(num_digits):
        return ExcelError('#VALUE!', '%s is not a number' % str(num_digits))

    number = float(number) # if you don't Spreadsheet.dump/load, you might end up with Long numbers, which Decimal doesn't accept

    if num_digits >= 0: # round to the right side of the point
        return float(Decimal(repr(number)).quantize(Decimal(repr(pow(10, -num_digits))), rounding=ROUND_UP))
        # see https://docs.python.org/2/library/functions.html#round
        # and https://gist.github.com/ejamesc/cedc886c5f36e2d075c5

    else:
        return ceil(number / pow(10, -num_digits)) * pow(10, -num_digits) 
開發者ID:vallettea,項目名稱:koala,代碼行數:18,代碼來源:excellib.py

示例6: insert

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def insert(self, kwds):
        endedAt = int(kwds.get('endedAt', None))
        startedAt = int(kwds.get('startedAt', None))
        elapsed = Decimal(kwds.get('elapsed', None))
        if elapsed:
            elapsed = elapsed.quantize(Decimal('.0001'), rounding=ROUND_UP)
        args = json.dumps(list(kwds.get('args', ())))  # tuple -> list -> json
        kwargs = json.dumps(kwds.get('kwargs', ()))
        context = json.dumps(kwds.get('context', {}))
        method = kwds.get('method', None)
        name = kwds.get('name', None)

        session = sessionmaker(self.db)()
        session.add(Measurements(
            endedAt=endedAt,
            startedAt=startedAt,
            elapsed=elapsed,
            args=args,
            kwargs=kwargs,
            context=context,
            method=method,
            name=name,
        ))
        session.commit() 
開發者ID:muatik,項目名稱:flask-profiler,代碼行數:26,代碼來源:sql_alchemy.py

示例7: random_amount

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def random_amount(rand, *, min_amount=Decimal('0.00'), max_amount=Decimal('10000.00')):
    drange = max_amount - min_amount
    return (min_amount + (drange * Decimal(rand.random()))).quantize(
        Decimal('.01'), rounding=decimal.ROUND_UP
    ) 
開發者ID:GamesDoneQuick,項目名稱:donation-tracker,代碼行數:7,代碼來源:randgen.py

示例8: pydecimal_equivalent_rounding_mode

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def pydecimal_equivalent_rounding_mode(self):
        return {
            RM.RM_TowardsPositiveInf:      decimal.ROUND_CEILING,
            RM.RM_TowardsNegativeInf:      decimal.ROUND_FLOOR,
            RM.RM_TowardsZero:             decimal.ROUND_DOWN,
            RM.RM_NearestTiesEven:         decimal.ROUND_HALF_EVEN,
            RM.RM_NearestTiesAwayFromZero: decimal.ROUND_UP,
        }[self] 
開發者ID:angr,項目名稱:claripy,代碼行數:10,代碼來源:fp.py

示例9: clean_amount

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def clean_amount(amount):
    return decimal.Decimal(str(amount)).quantize(decimal.Decimal('.01'), rounding=decimal.ROUND_UP) 
開發者ID:pedroburon,項目名稱:tbk,代碼行數:4,代碼來源:payment.py

示例10: usd

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def usd(self, amount: Decimal):
        self.pennies = int(amount.quantize(self.PENNY, ROUND_UP) * self.PENNIES) 
開發者ID:lbryio,項目名稱:lbry-sdk,代碼行數:4,代碼來源:attrs.py

示例11: currency_round_up

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def currency_round_up(money):
    return money.quantize(Decimal('1.00'), rounding=ROUND_UP) 
開發者ID:pyconsk,項目名稱:django-konfera,代碼行數:4,代碼來源:utils.py

示例12: round_up

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def round_up(n: Decimal, prec: int = 2) -> Decimal:
    return n.quantize(Decimal("." + "0" * prec), rounding=ROUND_UP) 
開發者ID:b2wdigital,項目名稱:asgard-api,代碼行數:4,代碼來源:__init__.py

示例13: adjust_quanity

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def adjust_quanity(self, q, round_down=True):
        if q == 0:
            return 0

        res = float(Decimal(q).quantize(self.stepSize, rounding=ROUND_DOWN if round_down else ROUND_UP))
        return float(min(max(res, self.minQty), self.maxQty)) 
開發者ID:iilunin,項目名稱:crypto-bot,代碼行數:8,代碼來源:ExchangeInfo.py

示例14: adjust_price

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def adjust_price(self, q, round_down=True):
        res = round(Decimal(q), 8)

        if self.tickSize:  # if tickSize Enabled
            res = res.quantize(self.tickSize, rounding=ROUND_DOWN if round_down else ROUND_UP)

        if self.minPrice:  # if minPrice Enabled
            res = max(res, self.minPrice)

        if self.maxPrice:  # if minPrice Enabled
            res = min(res, self.maxPrice)

        return float(res) 
開發者ID:iilunin,項目名稱:crypto-bot,代碼行數:15,代碼來源:ExchangeInfo.py

示例15: generate_donation

# 需要導入模塊: import decimal [as 別名]
# 或者: from decimal import ROUND_UP [as 別名]
def generate_donation(
    rand,
    *,
    donor=None,
    domain=None,
    event=None,
    min_amount=Decimal('0.01'),
    max_amount=Decimal('1000.00'),
    min_time=None,
    max_time=None,
    donors=None,
    transactionstate=None,
):
    donation = Donation()
    donation.amount = random_amount(rand, min_amount=min_amount, max_amount=max_amount)
    if event:
        donation.event = event
    else:
        donation.event = pick_random_instance(rand, Event)
    if domain:
        donation.domain = domain
    else:
        donation.domain = pick_random_element(rand, DonationDomainChoices)[0]
    donation.domainId = str(rand.getrandbits(64))
    donation.fee = (donation.amount * Decimal(0.03)).quantize(
        Decimal('0.01'), rounding=decimal.ROUND_UP
    )
    donation.comment = random_name(rand, 'Comment')
    donation.commentstate = 'APPROVED'
    donation.readstate = 'READ'
    if not min_time:
        min_time = event.datetime
    if not max_time:
        max_time = min_time + datetime.timedelta(seconds=60 * 60 * 24 * 14)
    donation.timereceived = random_time(rand, min_time, max_time)
    donation.currency = 'USD'
    donation.transactionstate = transactionstate or 'COMPLETED'
    if donation.domain == 'LOCAL':
        assert donation.transactionstate == 'COMPLETED'

    if not donor:
        if donors:
            donor = pick_random_element(rand, donors)
        else:
            donor = pick_random_instance(rand, Donor)
    if not donor:  # no provided donors at all
        donor = generate_donor(rand)
        donor.save()
    donation.donor = donor
    donation.clean()
    return donation 
開發者ID:GamesDoneQuick,項目名稱:donation-tracker,代碼行數:53,代碼來源:randgen.py


注:本文中的decimal.ROUND_UP屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。