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))

  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内的任意数字

最新文章

  1. 如何在CentOS/RHEL &amp; Fedora上安装MongoDB 3.2
  2. android studio 项目迁移编码问题
  3. Unity 摄像机组件
  4. GDB 调试 一些命令
  5. SpringMVC工作环境搭建 配置文件
  6. oracle相关环境变量配置
  7. TestNg依赖详解(三)------灵活的文件配置依赖
  8. [Cocos2D-x For WP8]CocosDenshion音频播放
  9. 浮动框控制及切换、banner随机数js
  10. FastDFS分布式文件系统安装与使用(单节点)
  11. appium testcase1(Java)
  12. 移动端图表插件jChart.js的修改
  13. 【leetcode】Trapping Rain Water(hard)
  14. 干货分享:让你分分钟学会 javascript 闭包
  15. JSON数据理解
  16. python 3.4.0 简单的print &amp;#39;hello world&amp;#39;,出错--SyntaxError: invalid syntax
  17. Google Daydream 在中国的第一次演讲摘录
  18. 手把手教你使用startuml画用例图
  19. 一次从0到1的java项目实践清单
  20. Logback日志基础配置以及自定义配置

热门文章

  1. jmeter------reponse报错”Unknown column &#39;XXXXX&#39; in &#39;where clause&#39;“
  2. 【PAT】1005. 继续(3n+1)猜想 (25)
  3. JavaScript与C#互通的DES加解密算法
  4. lr的脚本调试方法
  5. JQuery 分割字符串
  6. Python并发编程-生产消费模型
  7. [转]如何在 JS 代码中消灭 for 循环
  8. 【JAVAWEB学习笔记】19_事务概述、操作、特性和隔离级别
  9. 关于urllib、urllib2爬虫伪装的总结
  10. FastReport.Net使用:[4]分组