一、对数值进行取整:round(value,ndigits)

>>> round(15.5,-1)    #可以取负数
20.0
>>> round(15.5,0) #当某个值恰好等于两个整数间的一半时,取整操作会取到离该值最近的那个偶数上
16.0
>>> round(16.5,0) #如上同例
16.0

#float提供17位的精度

二、对小数进行精确计算:decimal模块(规避float天生的精度误差,但效率低,常用于金融领域)

>>> a = 1.1
>>> b = 2.2
>>> a + b
3.3000000000000003
>>> (a + b) == 3.3
False >>> from decimal import Decimal
>>> a = Decimal('1.1')
>>> b = Decimal('2.2')
>>> a + b
Decimal('3.3')
>>> print(a + b)
3.3
>>> print(float(a + b))
3.3

三、format()格式化输出:{「参数索引或名称」:「填充符」「对齐方式<>^」「width」「数值千分位,」「精度.ndigits」}.format("a", "b", ...)

>>> print("{0:=^20,.1f}, {1:+>20}".format(1000.235, 'haha'))
======1,000.2=======, ++++++++++++++++haha
>>> print("{b:=^20,.1f}, {a:+>20}".format(b=1000.235, a='haha'))
======1,000.2=======, ++++++++++++++++haha

  '!a' (应用 ascii()),'!s' (应用 str() )和 '!r' (应用 repr() )可以在格式化之前转换值

>>> print('{!a}'.format('1.001'))
'1.001'
>>> print('{!r}'.format('1.001'))
'1.001'
>>> print('{!s}'.format('1.001'))
1.001

  传入一个字典,用中括号( '[]' )访问它的键:

>>> table = {'a': 10,'b': 20}
>>> print('a is {1},b is {0}'.format(*table.values()))
a is 10,b is 20
>>> print('a is {0[a]},b is {0[b]}'.format(table))
a is 10,b is 20
>>> print('a is {a},b is {b}'.format(**table))
a is 10,b is 20

四、进制转换

>>> x = -1234
>>> bin(x) #十进制转二进制
'-0b10011010010'
>>> oct(x) #十进制转八进制
'-0o2322'
>>> hex(x) #十进制转十六进制
'-0x4d2'
>>> int(-0x4d2) #十六进制转十进制
-1234

五、Python中大部分和数学相关的模块都适用于复数,但Python的标准数学函数默认不能产生数值,若需要产生复数结果,须使用cmath模块

>>> import math
>>> math.sqrt(-1)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: math domain error
>>> import cmath
>>> cmath.sqrt(-1)
1j

六、正负无穷大(inf、-inf)、NaN(not a number,如两个无穷大之间的运算结果)

>>> a = float('inf')
>>> a
inf
>>> b = -a
>>> b
-inf
>>> b / 2
-inf
>>> 2 / b
-0.0
>>> a + b
nan
>>> a * b
-inf
注1:运算结果根据使用环境判断,inf、-inf具备传染性
注2:nan会通过所有的操作进行传播,且不会引发任何异常
注3:对两个nan进行逻辑比较的结果是False,唯一安全检测nan的方法是math.isnan()

七、处理分数:fractions模块

#允许用户以分数的形式输入,免去了用户手动将数据转换为float或Decimal对象的麻烦,提升用户体验

from fractions import Fraction
>>> a = Fraction(2, 3)
>>> b = Fraction(4, 5)
>>> a
Fraction(2, 3)
>>> b
Fraction(4, 5)
>>> a < b
True
>>> a + b
Fraction(22, 15)
>>> a * b
>>> float(a) #分数转化为浮点数
0.6666666666666666
>>> a.numerator #取分子
2
>>> a.denominator #取分母
3

八、大型数组计算:NumPy模块

  #NumPy为Python提供了数组对象,比标准Python中的列表有着更好的性能表现,更加适用于数学计算,底层实现上,NumPy采用和C相同的内存分配方式,即大块的连续内存,其效率通常比math模块中的函数快100倍左右

  NumPy中的数组在进行标量运算时是针对逐个元素进行计算的:

>>> import numpy as np    #惯例写为np
>>> ax = np.array([1, 2, 3, 4])
>>> ay = np.array([10, 12, 13, 14])
>>> ax * 2
array([2, 4, 6, 8])
>>> ax / 2
array([ 0.5, 1. , 1.5, 2. ])
>>> ax * ay
array([10, 24, 39, 56])
>>> ax - ay
array([ -9, -10, -10, -10])

  NumPy中提供了一些“通用函数”集合,可用于math模块中对应函数的替代:

>>> math.sqrt(4)
2.0
>>> np.sqrt(4) #效率更高
2.0
>>> np.sqrt(ay) #math.sqrt()不能计算数组对象
array([ 3.16227766, 3.46410162, 3.60555128, 3.74165739])
>>> np.sin(ax)
array([ 0.84147098, 0.90929743, 0.14112001, -0.7568025 ])

  NumPy扩展了Python列表的索引功能(尤其是多维数组方面):

>>> az = np.array([[1, 2, 3, 4],[5, 6, 7, 8],[9, 10, 11, 12],[13, 14, 15, 16]])
>>> az
array([[ 1, 2, 3, 4],
[ 5, 6, 7, 8],
[ 9, 10, 11, 12],
[13, 14, 15, 16]])
>>> az[0:2,2:4]
array([[3, 4],
[7, 8]])
>>> az[0:2,:]
array([[1, 2, 3, 4],
[5, 6, 7, 8]])
>>> az[0:2]
array([[1, 2, 3, 4],
[5, 6, 7, 8]])
>>> az[:,1:3] #取第2、3两列
array([[ 2, 3],
[ 6, 7],
[10, 11],
[14, 15]])
>>> az[,1:3] #只取列的时候,行部分不能留空!
File "<stdin>", line 1
az[,1:3]
^
SyntaxError: invalid syntax

  条件替换(逻辑类似于列表推导式):

>>> np.where(az>10, 100, 99)
array([[ 99, 99, 99, 99],
[ 99, 99, 99, 99],
[ 99, 99, 100, 100],
[100, 100, 100, 100]])
>>> np.where(az>10, az, 99)
array([[99, 99, 99, 99],
[99, 99, 99, 99],
[99, 99, 11, 12],
[13, 14, 15, 16]])

九、矩阵与线性代数计算:numpy.matrix

>>> type(mz)
<class 'numpy.matrixlib.defmatrix.matrix'>
>>> mz
matrix([[ 1, 2, 3, 4],
[ 5, 6, 7, 8],
[ 9, 10, 11, 12],
[13, 14, 15, 16]])
>>> mz.T #矩阵行列转置
matrix([[ 1, 5, 9, 13],
[ 2, 6, 10, 14],
[ 3, 7, 11, 15],
[ 4, 8, 12, 16]])

十、随机选择:random模块(可用于均匀分布、正态分布、高斯分布等概率分布计算,不可用于加密,加密可用ssl模块)

  从队列中随机选取N个元素:

>>> b
[1, 2, 3, 4, 8, 9]
>>> random.sample(b, 1)
[2]
>>> random.sample(b, 1)
[3]
>>> random.sample(b, 3)
[3, 2, 8]
>>> random.sample(b, 3)
[4, 9, 2]

  原地打乱元素的顺序:

>>> o
[6, 3, 2, 4, 5, 7, 1]
>>> random.shuffle(o)
>>> o
[1, 3, 5, 7, 6, 2, 4]

  产生随机整数:

>>> random.randint(-100,10)
-80
>>> random.randint(-100,10)
5

  产生0-1之间的随机浮点数:

>>> random.random()
0.08408738274480865
>>> random.random()
0.3307587395045867

  由N个随机bits所表示的整数(即N位随机二进制数字所表示的int):

>>> random.getrandbits(10)
932
>>> random.getrandbits(10)
684
>>> random.getrandbits(100)
449049712738822352045673826991
>>> random.getrandbits(100)
838121576315938044329535728101

十一、显示当天的日期

>>> from datetime import datetime
>>> datetime.today()
datetime.datetime(2016, 8, 11, 13, 8, 2, 369594)

最新文章

  1. javascript函数
  2. Ubuntu16.04下部署golang开发环境
  3. WEBSTORM 打开多个项目的方法
  4. POJ 1062 ( dijkstra )
  5. Nginx负载均衡深入浅出
  6. .net微信公众号开发——模板消息
  7. Android项目结构分析
  8. hdoj 1269 迷宫城堡【scc基础题目】
  9. Map(关联式容器)
  10. UrlEncode编码/UrlDecode解码
  11. Set接口下的集合
  12. J2CACHE 两级缓存框架
  13. 常见Chrome 插件
  14. XmlDocument操作
  15. .NET Core installation for Docker
  16. 【转】WCF扩展系列 - 行为扩展(Behaviors)
  17. appium----新版appium 1.11.1 支持ByName定位
  18. c# 之Web.config
  19. “全栈2019”Java异常第二章:如何处理异常?
  20. oracle 11g各种下载地址

热门文章

  1. CF1016F 【Road Projects】
  2. 2019 ACM/ICPC Asia Regional shanxia D Miku and Generals (二分图黑白染色+01背包)
  3. 大数运算之 Java BigInteger 的基本用法
  4. PAT_A1101#Quick Sort
  5. 全网最热Python3入门+进阶 更快上手实际开发✍✍✍
  6. Pytest初体验
  7. 三.Python数据类型详述
  8. linux安装lolcat实现彩色文字输出信息
  9. sqlldr details
  10. hadoop&ndash;JobTracker 相关