Python 数字类型之 int float

Posted 小小程序员ol

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 数字类型之 int float相关的知识,希望对你有一定的参考价值。

数字常量

  • int:  一般的整数,

  • long: 长整型,2.x版本需在数字后加 “L” 或 “l” ,表示长整型 如 100000000L; python3.x 版本后不分长整型,统一为int,不可加 “L” 或 “l”

  • float: 浮点数,1.0 也为浮点数,float 可强制转换为 int,取整;

print(type(1234))
print(type(-24))
print(type(0))
print(type(2147483647))      # 为int
print(type(2147483648))      # >=2^31 为long    Python2.x ; Python3.x long 和 int 合并为 int
i = 1l                       # Python2.x 表示long,Python3 会报错
print(i,type(i))
print(type(i))
print(type(1e+1))            # e表示法为浮点型
print(int(1e+20))            # 强制转换为int
print(int(1e+30))            # 超长精度丢失
print(type(1.0))             # 小数表示为float
print(int(1.999))            # int()强制转换为int 会把float取整

数字计算

加减乘数运算

a=1
b=2
c=2.0
print(a+b)
print(type(a+b))
print(a-c)          # 输出 -1.0
print(type(a+c))    # 有浮点型加入,即自动转换为 float
print(a*b)
print(type(a*b))    # 两个整数相乘,仍为整数型
print(type(a*c))    # 有浮点型加入,即自动转换为 float
print(a/b)
print(type(a/b))
print(b/a)
print(type(b/a))    # 除法运算,即使整除,结果仍为 float 类型

备注: print(1/0) 除数为0会报错,而不是返回 NaN;一定要 注意 除数为0时的异常判断;如需处理 NaN,需 from decimal import *

Decimal numbers include special values such as NaN which stands for “Not a number”, positive and negative Infinity, and -0

取余运算、指数幂运算、取绝对值、四舍五入

print(3%2)                # 通常就做整数间的取余运算
print(type(3%2))
print(type(3.0%2))        # 不建议浮点型取余
print(2.1%2)              # 虽然float也可运算取余,但结果带精度,此结果为0.10000000000000009
print(3**2)               # ** 表示做次方运算,即幂运算
print(type(3**2))         # 整数的整数次幂仍为整数
print(2**-2)
print(type(2**-2))
print(1**-2)
print(type(1**-2))        # 负数次幂均为 float
print(4**0.5)
print(type(4**0.5))       # 非整数次幂均为 float
print(pow(2,3))           # 指数幂的另一表示法
print(abs(-1))            # 取绝对值
print(round(3.5))         # 四舍五入取整
print(round(3.49))        # 四舍五入取整
print(round(3.49,1))      # 可加一参数,表示取小数点后几位四舍五入,如上结果为 3.5
print(round(3.04,1))

数字比较

比较运算符 == != > >= < <=

a = 1
b = 1.0
print(a==b)            # 数值的比较 返回 True

进制数

2进制数以 0b 开头表示,8进制数以 0o 开头表示(零和小写o),16进制数以 0x 开头表示;bin() 会以二进制输出形式

a = 0b11100                # 2进制数  0b 开头
b = 0o34                   # 8进制数  0o 开头
c = 0x1c                   # 16进制数 0x开头
print(a,b,c)
print(bin(2))              # bin()表示以二进制输出

位运算

同很多语言一样,Python的位运算符包括 << >> & | ~ ^

print(bin(0b110<<2))          # 左移2位
print(bin(0b110>>1))          # 右移1位
print(0&0,0&1,1&0,1&1)        # & 与运算
print(0|0,0|1,1|0,1|1)        # | 或运算
print(0^0,0^1,1^0,1^1)        # ^ 异或运算
print(bin(~0b11))             # ~ 非运算,有符号数的取反

Math 模块

复杂的数学计算需导入数学模块,即 import math ; 仅列出 math 模块中一些常用的常量、函数等;具体要用时参阅官方帮助文档。

import math
print(math.e)                       # 数学常量e
print(math.pi)                      # 数学常量pi
print(math.ceil(3.00001))           # 向上取整
print(math.floor(3.99999))          # 向下取整
print(math.sqrt(9))                 # 平方根 math.sqrt(x) == x**0.5  同样返回 float 类型
print(math.exp(1))                  # exp(n)  math.e的n次方
print(math.log(math.e))             # 即Ln运算 即以自然常数e (2.71828......)为底数的对数
print(math.log(16,2))               # 以2为底,16的对数
print(math.log(1,10))               # 以10为底,1的对数
print(math.degrees(math.pi))        # Converts angle x from radians to degrees.
print(math.radians(60))             # Converts angle x from degrees to radians.
print(math.sin(math.radians(30)))   # 精度丢失
print(math.cos(math.pi/3))			#小编创建了一个Python学习交流群:725638078

Random 模块

random 模块可产生多种随机数;这里仅介绍 randint:产生范围内的随机整数;若需其他随机数方法,具体要用时参阅官方帮助文档。

random.randint(a, b) 
Return a random integer N such that a <= N <= b.
from random import randint
for i in range(1,11):            # 表示做十次循环
    print(randint(1,10))         # 输出1到10内的任意数字 

Python基本数据类型之数字int

  • int(x, base=None) 将x转换为一个整数。base为按照多少进制进行转换

  • float(x) 将x转换到一个浮点数。

  • complex(x) 将x转换到一个复数,实数部分为 x,虚数部分为 0。

  • complex(x, y) 将 x 和 y 转换到一个复数,实数部分为 x,虚数部分为 y。x 和 y 是数字表达式。

  • bit_lenght 当前数字二进制后,至少用几位表示

数学函数

函数返回值 ( 描述 )
abs(x) 返回数字的绝对值,如abs(-10) 返回 10
ceil(x) 返回数字的上入整数,如math.ceil(4.1) 返回 5

cmp(x, y)

如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1。 Python 3 已废弃 。使用 使用 (x>y)-(x<y) 替换。
exp(x) 返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045
fabs(x) 返回数字的绝对值,如math.fabs(-10) 返回10.0
floor(x) 返回数字的下舍整数,如math.floor(4.9)返回 4
log(x) 如math.log(math.e)返回1.0,math.log(100,10)返回2.0
log10(x) 返回以10为基数的x的对数,如math.log10(100)返回 2.0
max(x1, x2,...) 返回给定参数的最大值,参数可以为序列。
min(x1, x2,...) 返回给定参数的最小值,参数可以为序列。
modf(x) 返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。
pow(x, y) x**y 运算后的值。
round(x [,n]) 返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。
sqrt(x) 返回数字x的平方根,数字可以为负数,返回类型为实数,如math.sqrt(4)返回 2+0j

三角函数

函数描述
acos(x) 返回x的反余弦弧度值。
asin(x) 返回x的反正弦弧度值。  
atan(x) 返回x的反正切弧度值。
atan2(y, x) 返回给定的 X 及 Y 坐标值的反正切值。
cos(x) 返回x的弧度的余弦值。
hypot(x, y) 返回欧几里德范数 sqrt(x*x + y*y)。
sin(x) 返回的x弧度的正弦值。
tan(x) 返回x弧度的正切值。
degrees(x) 将弧度转换为角度,如degrees(math.pi/2) , 返回90.0
radians(x) 将角度转换为弧度

数学常量

常量描述
pi 数学常量 pi(圆周率,一般以π来表示)
e 数学常量 e,e即自然常数(自然常数)。
 
 
 

以上是关于Python 数字类型之 int float的主要内容,如果未能解决你的问题,请参考以下文章

python之数据类型(数字与列表)

python基础之数据类型

python学习08——基本数据类型的内置方法之数字类型与字符串类型

3-Python3从入门到实战—基础之数据类型(数字-Number)

Python数据类型之数字

Python的数据类型之Number