python数学模块(math/decimal模块)

目录
  • 一, math模块
    • 2. math库常用函数
    • 3.math库使用示例
  • 二, decimal模块
    • 1. 什么时候使用decimal
    • 2. 使用decimal
    • 3. decimal使用示例

一, math模块

math库是python提供的内置数学类函数库,math库不支持复数类型,仅支持整数和浮点数运算。

常数 说明 实例
math.pi 圆周率Π math.pi输出结果:3.141592653589793
math.e 自然常数e math.e输出结果:2.718281828459045
math.inf 正无穷大,
-math.inf是负无穷大
math.inf输出 inf
math.nan 非浮点数标记,NaN math.nan输出结果:nan

2. math库常用函数

函数名 说明
math.ceil(f) 向上取整,返回值:整数值
math.floor(f) 向下取整,返回值:整数
round(f) 四舍五入,返回值:整数
math.fabs(f) 获取绝对值操作,返回值:浮点数
abs(num) 获取绝对值操作,返回值:根据传入的参数而定
math.fmod(x,y) 返回x/y的余数,返回值:浮点数
math.pow(x,n) 返回x的n次方,返回值:浮点型
math.sqrt(num) 对num开平方,返回值:浮点数
fsum(seq) 返回序列中所有元素的和,返回值:浮点数
sum(seq) 将一个序列的数值进行相加求和,返回值:根据序列中数值的类型变化
math.modf(num) 将一个浮点数拆成小数和整数部分组成的元组,返回值:元组
math.trunc(f) 返回浮点数的整数部分,返回值:整数
math.copysign(n1,n1) 将第二个数的正负号赋值给第一个数,返回值:浮点数
math.factorial(x) 返回x的阶乘,如果x不是整数或为负数将引发ValueError,返回值:整数
math.gcd(x,y) 返回整数x和y的最大公约数,返回值:整数

3.math库使用示例

# -*- coding: utf-8 -*-
import math

# math库常用变量
print("math.pi = ", math.pi)
print('math.e = ', math.e)
print('math.inf = ', math.inf)
print('math.nan = ', math.nan)

# math库常用函数

print('math.ceil()向上取整,math.ceil(2.3) = ', math.ceil(2.3))
print('math.ceil()向上取整,math.ceil(2.5) = ', math.ceil(2.5))
print('math.ceil()向上取整,math.ceil(2.0) = ', math.ceil(2.0))
print('math.ceil()向上取整,math.ceil(2.8) = ', math.ceil(2.8))
print('math.ceil()向上取整,math.ceil(-2.8) = ', math.ceil(-2.8))

print('math.floor()向下取整,math.floor(2.3) = ', math.floor(2.3))
print('math.floor()向下取整,math.floor(2.5) = ', math.floor(2.5))
print('math.floor()向下取整,math.floor(2.0) = ', math.floor(2.0))
print('math.floor()向下取整,math.floor(2.8) = ', math.floor(2.8))
print('math.floor()向下取整,math.floor(-2.8) = ', math.floor(-2.8))

print('round()四舍五入,round(2.3) = ', round(2.3))
print('round()四舍五入,roundr(2.5) = ', round(2.5))
print('round()四舍五入,round(2.0) = ', round(2.0))
print('round()四舍五入,round(2.8) = ', round(2.8))
print('round()四舍五入,round(-2.8) = ', round(-2.8))

print('math.fabs()获取绝对值,math.fabs(2.3) = ', math.fabs(2.3))
print('math.fabs()获取绝对值,math.fabs(-2.3) = ', math.fabs(-2.3))
print('math.fabs()获取绝对值,math.fabs(-2.0) = ', math.fabs(-2.0))
print('math.fabs()获取绝对值,math.fabs(-2) = ', math.fabs(-2))

print('abs()获取绝对值,abs(2.3) = ', abs(2.3))
print('abs()获取绝对值,abs(-2.3) = ', abs(-2.3))
print('abs()获取绝对值,abs(-2.0) = ', abs(-2.0))
print('abs()获取绝对值,abs(-2) = ', abs(-2))

print('math.fmod(x,y)获取x/y的余数,math.fmod(2,3) = ' ,math.fmod(2,3))
print('math.pow(x,y)获取x的n次方,math.pow(2,3) = ', math.pow(2,3))
print('math.sqrt()获取开放根,math.sqrt(4) = ', math.sqrt(4))
print('fsum()获取序列中所有元素的和,fsum([1,2,3,4,5,6]) = ', math.fsum([1,2,3,4,5,6]))
print('sum()获取序列中所有元素的和,sum([1,2,3,4,5,6]) = ', sum([1,2,3,4,5,6]))
print('math.modf()获取浮点数的小数和整数部分,math.modf(2.3) = ', math.modf(2.3))
print('math.trunc()获取浮点数的整数部分,math.trunc(2.3) = ', math.trunc(2.3))
print('math.copysign(n1,n2)把第二个数的正负号赋值给第一个浮点数,math.copysign(-2.3,1) = ', math.copysign(-2.3,1))
print('math.copysign(n1,n2)把第二个数的正负号赋值给第一个浮点数,math.copysign(2.3,-1) = ', math.copysign(2.3,-1))
print('math.gcd(x,y)获取x和y的最大公约数,math.gcd(16,24) = ', math.gcd(16,24))
try:
    print('math.factorial()获取阶乘,math.factorial(3) = ', math.factorial(3))
    print('math.factorial()获取阶乘,math.factorial(2.3) = ', math.factorial(2.3))
    print('math.factorial()获取阶乘,math.factorial(-2) = ', math.factorial(-2))
except ValueError as e:
    print(e)
finally:
    pass

二, decimal模块

decimal模块提供了一个Decimal数据类型用于浮点数计算。相比内置的二进制浮点数实现float,Decimal有助于金融应用和其它需要精确十进制表达的场合,控制精度,控制舍入以适应法律或者规定要求,确保十进制数位精度,或者用户希望计算结果与手算相符的场合。
Decimal重现了手工的数学运算,确保了二进制浮点数无法精确保有的数据精度。高精度使Decimal可以执行二进制浮点数无法进行的模运算和等值测试。

1. 什么时候使用decimal

python中小数相加可能计算结果不对,是由于科学计算精度问题,如果需要处理这个问题就需要用到decimal模块。

2. 使用decimal

设置精度:decimal.getcontext().prec = num,num为有效数字个数

设置小数位数:quantize()

注意:decimal.getcontext().prec 和 quantize()不能同时使用,如果同时使用会提示错误:decimal.InvalidOperation: [<class ‘decimal.InvalidOperation’>]

3. decimal使用示例

# -*- coding: utf-8 -*-
import decimal

"""
decimal.getcontext().prec = 3  # 设置有效数字是3位
print(decimal.Decimal(2.32) + decimal.Decimal(3.01))

decimal.getcontext().prec = 2  # 设置有效数字是2位
print(decimal.Decimal(2.32) + decimal.Decimal(3.01))
"""

# quantize()设置小数位数
num = decimal.Decimal(1.23456789).quantize(decimal.Decimal('0.000'))
print(num)

到此这篇关于python数学模块(math/decimal模块)的文章就介绍到这了,更多相关python数学模块内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 实例详解Python模块decimal

    Python提供了decimal模块用于十进制数学计算,它具有以下特点: 1.提供十进制数据类型,并且存储为十进制数序列: 2.有界精度:用于存储数字的位数是固定的,可以通过decimal.getcontext().prec=x 来设定,不同的数字可以有不同的精度 3.浮点:十进制小数点的位置不固定(但位数是固定的) decimal的构建: 可以通过整数.字符串或者元组构建decimal.Decimal,对于浮点数需要先将其转换为字符串 decimal的context: decimal在一个独立

  • Python decimal模块使用方法详解

    decimal 模块:decimal意思为十进制,这个模块提供了十进制浮点运算支持 1.可以传递给Decimal整型或者字符串参数,但不能是浮点数据,因为浮点数据本身就不准确. 2.要从浮点数据转换为Decimal类型 from decimal import * Decimal.from_float(12.222) # 结果为Decimal('12.2219999999999995310417943983338773250579833984375') 3.通过设定有效数字,限定结果样式 from

  • 在Python中处理字符串之isdecimal()方法的使用

    isdecimal()方法检查字符串是否仅由十进制字符组成.此方法只存在于unicode对象. 注意:要定义一个字符串为Unicode,只需前缀分配'u'左引号.以下是示例. 语法 以下是isdecimal()方法的语法: str.isdecimal() 参数 NA 返回值 如果字符串中的所有字符为十进制此方法返回true,否则返回false. 例子 下面的例子显示了isdecimal()方法的使用. #!/usr/bin/python str = u"this2009"; print

  • python中decimal模块的具体使用

    decimal模块主要的作用是精确小数,因为float是不精确的,只是无限接近,对于一些需要精确小数点后位数的就需要用decimal. Decimal类型的优点 Decimal类型是在浮点类型的基础上设计的,但是它在几个地方上要优于floating point: Decimal类型可以非常精确地在计算机中存储,浮点型在计算机中是无法精确存储的,后面的小数会不精确,Decimal类型则不会出现这种情况.同样,由于无法精确存储,浮点型也就无法精确计算. Decimal类型会自动保留小数点后面不需要的

  • python中的decimal类型转换实例详解

    [Python标准库]decimal--定点数和浮点数的数学运算 作用:使用定点数和浮点数的小数运算.         Python 版本:2.4 及以后版本 decimal 模块实现了定点和浮点算术运算符,使用的是大多数人所熟悉的模型,而不是程序员熟悉的模型,即大多数计算机硬件实现的 IEEE 浮点数运算.Decimal 实例可以准确地表示任何数,对其上取整或下取整,还可以对有效数字个数加以限制. Decimal 小数值表示为 Decimal 类的实例.构造函数取一个整数或字符串作为参数.使用

  • python中decimal模块的用法

    目录 1. Decimal类型的优点 2. decimal模块的构成 3. context 4. Signals 5. Round类型 查看python3.4.1文档,发现对于decimal模块的讲解非常多,由此可见其功能也很强大(下面算是把我认为比较重要的半翻译半学习吧~).文档关于decimal模块的总解释是Decimal fixed point and floating point arithmetic,我理解的是固定小数点和浮点运算.头加上from decimal import * 即可

  • python数学模块(math/decimal模块)

    目录 一, math模块 2. math库常用函数 3.math库使用示例 二, decimal模块 1. 什么时候使用decimal 2. 使用decimal 3. decimal使用示例 一, math模块 math库是python提供的内置数学类函数库,math库不支持复数类型,仅支持整数和浮点数运算. 常数 说明 实例 math.pi 圆周率Π math.pi输出结果:3.141592653589793 math.e 自然常数e math.e输出结果:2.718281828459045

  • 表格梳理python内置数学模块math分析详解

    python内置数学模块math 提供了一些基础的计算功能,下列表达式默认 from math import * 默认输入输出均为一个数字.大部分函数都很直观,望文生义即可. 其他函数 isclose(a, b, *, rel_tol=1e-09, abs_tol=0.0) 若 a 和 b 的值比较接近则返回True,否则False. rel_tol 是相对容差,表示a, b之间允许的最大差值.例如,要设置5%的容差,rel_tol=0.05.rel_tol 必须大于0. abs_tol 是最小

  • 一篇文章带你了解python标准库--math模块

    目录 1. math模块中的常用函数 2. 案例 2.1 浮点数求整 2.2 对元组里的每个元素求和 2.3 求数的绝对值 总结 python语言的一大优势:为科学计算提供了大量的支持功能,math模块提供了很多数学计算函数. math模块定义了一些数学模块,这个模块属于编译系统自带,因此它可以被无条件调用,需要注意的是,这些函数无法应用于复数. 1. math模块中的常用函数 2. 案例 2.1 浮点数求整 1.用trunc(x)取整,x为浮点数 >>> import math >

  • Python标准库之Math,Random模块使用详解

    目录 数学模块 ceil -- 上取整 floor -- 下取整 四舍五入 pow -- 幂运算 sqrt -- 开平方运算 fabs -- 绝对值 modf -- 拆分整数小数 copysign -- 正负拷贝 fsum -- 序列和 pi -- 圆周率常数 factorial -- 因数 随机模块 random -- 获取 0~~1 之间的小数 randrange -- 获取指定范围内的整数 randint -- 获取指定范围整数 uniform -- 获取指定范围内随机小数(左闭右开) c

  • Python中的sys模块、random模块和math模块

    一.sys运行时环境模块 sys模块负责程序与python解释器的交互,提供了一系列的函数和变量,用于操控python的运行时环境. 用法: sys.argv:命令行参数List,第一个元素是程序本身路径 sys.modules.keys():返回所有已经导入的模块列表 sys.exc_info():获取当前正在处理的异常类,exc_type.exc_value.exc_traceback当前处理的异常详细信息 sys.exit(n):退出程序,正常退出时exit(0) sys.hexversi

  • Python处理命令行参数模块optpars用法实例分析

    本文实例讲述了Python处理命令行参数模块optpars用法.分享给大家供大家参考,具体如下: optpars是python中用来处理命令行参数的模块,可以自动生成程序的帮助信息,功能强大,易于使用,可以方便的生成标准的,符合Unix/Posix 规范的命令行说明. 使用 add_option() 来加入选项,使用 parse_args() 来解析命令行. add_option()中参数 第一个参数表示option的缩写,以单个中划线引导,例如-f.-d,只能用单个字母,可以使用大写; 第二个

  • Python Datetime模块和Calendar模块用法实例分析

    本文实例讲述了Python Datetime模块和Calendar模块用法.分享给大家供大家参考,具体如下: datetime模块 1.1 概述 datetime比time高级了不少,可以理解为datetime基于time进行了封装,提供了更多的实用的函数,datetime的接口更加的直观,更容易调用 1.2 模块中的类 datetime:同时有时间与日期 timedelta:表示时间间隔,即两个时间点的间隔:主要用于计算时间的跨度 tzinfo: 时区相关的信息 date : 只关注日期 2.

随机推荐