新大榭论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

《新大榭》- 创大榭地方网络社区先锋品牌 新大榭始终专注于地方网络社区平台的建设 关于我们- [大记事]- 留言建议- [新手报道]

发布 .新大榭软件管家(Excel版) V5.9版 财务/仓库/生产/销售/采购/行政/人事/校园 .公告 - 客户 - 打赏 - 职场 - Excel - Python.

新大榭镜像-音乐-法律-图书-高中课堂-实验 广告是为了能更好的发展 [欢迎商家支持本站互利共赢] 广告位招租.首页黄金广告位等您来!联系 13566035181

查看: 244|回复: 1

[模块] 7290 - python库【decimal】数据精度模块介绍

 关闭 [复制链接]
发表于 2021-6-17 22:04:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!

您需要 登录 才可以下载或查看,没有账号?注册

x
decimal 模块为快速正确舍入的十进制浮点运算提供了支持。% f/ {( S) r7 R: C$ k' \( g
//  它提供float数据类型有以下几个优点:

4 d8 N% p# W% }# u5 U- c7 ~
  • 十进制数字可以准确表示:数字如 1.1 和 2.2 在二进制浮点中没有精确的表示。7 {2 Q& s) Q# A, Y: q% I/ H# a
  1. >>> 1.1 + 2.2( [! P9 N! f+ O, F+ h/ P% Z& ?
  2. 3.3000000000000003  D( u: {. ]7 e) l7 S
  3. >>> from decimal import Decimal
    % _( U9 s3 T2 Z7 Y; U' g. f- G
  4. >>> Decimal('1.1') + Decimal('2.2')
    , {( F% ^9 E: p% s
  5. Decimal('3.3')
复制代码
  • 精确性延续到算术中。
  • 保留尾随零以表示重要性。2 M6 e1 V, S  m) s% a
  1. >>> 1.20*1.305 b9 w5 k! c9 P
  2. 1.56
    . h. M" {: Y6 u; _
  3. >>> Decimal('1.20')*Decimal('1.30')
      L8 i. A+ D5 D8 ^& Q
  4. Decimal('1.5600')
复制代码

常用方法
" C# U& N) o9 O* s
  1. class decimal.Decimal(value="0", context=None)
复制代码

3 c. m5 I5 {: ]. t
  • 可以传递给Decimal整型或者字符串参数,但不能是浮点数据,因为浮点数据本身就不准确。
    1 J/ v& s6 ^# |2 X  U
    1. >>> from decimal import *
        U" E- l" p. \2 d5 M
    2. >>> Decimal(1.1) + Decimal(2.2)1 G4 O0 {6 s& m  L  a
    3. Decimal('3.300000000000000266453525910'
      " A$ M- f6 P# U! B) Y( r
    4. >>> Decimal('1.1') + Decimal('2.2')' f7 _: f  D3 Z) l
    5. Decimal('3.3')
    复制代码
    9 P1 }" w" m$ ?4 W4 U
  • 通过设定有效数字,限定结果样式。
    6 C+ u' I) Q6 U: |
    1. >>> getcontext().prec = 6
      - E* Z+ `! O' o3 j% q* s0 j
    2. >>> Decimal(1)/Decimal(7)
      ' \$ F( R$ u2 H0 |) G+ |
    3. Decimal('0.142857')
      7 W, d# \) q; p+ b4 P3 z. |; L+ p
    4. >>> getcontext().prec = 28" O/ `2 |  r) ]1 \+ G3 ^  Q
    5. >>> Decimal(1) / Decimal(7)4 c/ T5 M, ], x1 P/ L
    6. Decimal('0.1428571428571428571428571429')
    复制代码
    & E/ j3 F8 b" x
  • 四舍五入,保留几位小数。% l3 i9 `- S) Q- j/ g. I5 T
    1. >>> Decimal('12.3456').quantize(Decimal('0.00'))+ _" ~  K' i* i# s
    2. Decimal('12.35')
      , ?0 B; `8 f* @* U) H7 ~
    3. >>> Decimal('12.3456').quantize(Decimal('1.1'))
      5 v2 x" I. ?8 u1 m0 |1 b
    4. Decimal('12.3')
    复制代码
    % k4 ~% Q+ a0 ?9 _
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
Q群推荐 大榭本地求职招聘QQ群,欢迎转发分享本地招聘信息资讯! 官方招聘1群(已满);官方招聘2群:315816937 *
 楼主| 发表于 2021-9-22 15:33:58 | 显示全部楼层
我们先来看一下这个计算题:
$ k- w5 b! |2 k8 P. W5 Y' e
  1. print(0.3-3*0.1)
复制代码
很显然我们知道答案是 02 w4 O7 p$ X2 \5 j1 P+ S
但是在python的世界里,答案却是 -5.551115123125783e-17
2 o9 X" {2 z% l5 Y1 |: x; m为什么呢?这是由于python的精度造成的,我们可以通过引入Decimal模块解决。
python中存在一个模块decimal,decimal模块实现了定点和浮点算术运算符,使用的是大多数人所熟悉的模型,而不是程序员熟悉的模型,即大多数计算机硬件实现的IEEE浮点数运算。Decimal实例可以准确地表示任何数,对其上取整或下取整,还可以对有效数字个数加以限制。
$ I, E% C, s5 c$ Z
如下所示:
  1. from decimal import Decimal as D
    ' f3 O, I, H( P* ~+ G3 M) a
  2. X = D(‘0.3’) - D(‘3’)  * D(‘0.1’) $ v0 b# F% k3 ^$ H, e. d" i; o
  3. print(float(X))
复制代码
% {: c. p4 R4 [3 P! L
  1. from decimal import Decimal. f& K+ s4 t2 n  Q  |( P
  2. a=0.3
    ( L0 D* b% x# p% l% ~1 m* v
  3. b=3
    ' F9 N- R: N/ |6 Y1 Y! [( H# B1 k
  4. c=0.15 a: `: g/ Z# @! |9 R) V
  5. X = Decimal(str(a)) - Decimal(str(b))  * Decimal(str(c))
    . t$ x, F0 q) E4 x8 s1 v% k% `, e* S
  6. print(X)
复制代码
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
新大榭官方公益帮帮群:6603298 官方Excel学习交流群:82064486  欢迎您加入
您需要登录后才可以回帖 登录 | 注册

本版积分规则

文字版|小黑屋|新大榭 ( 浙ICP备16018253号-1 )|点击这里给站长发消息|

GMT+8, 2026-1-9 19:23 , Processed in 0.097728 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表