1、数字类型简单介绍

  • Python中数字类型包含:整型、长整型、布尔型、双精度浮点型、十进制浮点型、复数。这些数字类型都是不可变类型。也就是说,改变了数字的值会生成新的对象。

  • 在Python中删除数字对象,能够用语句:del aInt,aLong,aFloat,aComplex


2、整型

  • 布尔型

    取值范围唯独两个值。True和False。

    它们在数学运算中相应1和0.

    对于值为0的不论什么数字或空集(空列表、空元组、空字典等)在Python中的布尔值都是False。

  • 长整型

    在其它编程语言中,比方C++中。int占用了32位。long int则取决于机器字长,long long int为64位。而在Python中。标准整型一般也是占用32位。可是假设在64位机器上用64位的编译器编译Python。则整型占用64位。

    Python中长整型能够支持的范围非常大,只取决机器支持的虚拟内存大小。长整型的声明:直接在数字后加L:12345L

    Python中整型与长整型逐渐统一为一种,所以使用时不用去关心整型还是长整型。



3、双精度浮点型

Python中的浮点型相似C中的double型,是双精度浮点型。占用64位。



4、复数

Python中的复数类型规定:

  • 复数由实数部分和虚数部分构成:real + imagj
  • 虚数部分不能单独存在,必须与0.0的实数部分一起构成复数
  • 实数部分real和虚数部分imag都是浮点类型。
  • 复数类型有三个内建属性: real、imag、conjugate(返回共轭复数)
>>> aComplex = 1.0 + 2.0j
>>> aComplex.real
1.0
>>> aComplex.imag
2.0
>>> aComplex.conjugate()
(1-2j)


5、操作符

自己主动类型转换

当对两个不同类型的数进行操作时。Python会自己主动进行类型转换。

主要的原则就是:整型转换为浮点型,非复数转换为复数。


真正的除法 vs 地板除

如今Python的版本号中调用除号“/”,运行的都是真正的除法:

>>> 1/2
0.5
>>> 1.0/2.0
0.5

另外另一种除法叫做地板除,它无论操作数为何种类型,总是舍去小数部分,能够通过符合“//”实现:

>>> 1.0//2.0
0.0

冪运算

通过操作符 ** 实现,注意各种符号的优先级,或者直接通过括号()消除优先级带来的歧义:

>>> -2**4
-16
>>> (-2)**4
16

位操作符

Python整型支持标准位运算:取反 ~ 、按位与 & 、按位或 | 、按位异或^ 、左移<< 、右移>>



6、工厂函数

  • 标准类型函数如cmp()、str()、type()
  • 数字类型函数
    • 转换工厂函数:int()、long()、float、conplex()
    • 功能函数:
      • abs(num),返回绝对值
      • corece(num1,num2)将num1、num2转换为同类型,然后以元组形式返回
      • divmod(num1,num2),返回(num1/num2,num1%num2)
      • pow(num1,num2),实现num1**num2
      • round(flt,ndig=0),对浮点数flt四舍五入,保存ndig位小数。默觉得0。
  • 仅用于整型的函数
    • 进制转换函数,oct()、hex()
    • ASCII转换函数
      • chr()接受一个单字节整型值,返回相应的字符
      • ord()接受一个字符。返回相应的整型值
>>> chr(97)
'a'
>>> ord('a')
97


7、相关模块

  • decimal 十进制浮点运算类 Decimal
  • array 高效数值数组
  • math/cmath 标准C库数学运算函数。常规数学运算在math中,复数运算在cmath中
  • operator 数学操作符的函数实现,比方 operator.sub(2,1)相当于2-1
  • random 多种伪随机数生成器
>>> import operator
>>> operator.sub(2,1)
1
>>> import random
>>> random.randint(0,10)
3
>>> random.randint(0,10)
7


转载请注明出处:http://blog.csdn.net/u012162613/article/details/44286655

《Python核心编程》数字类型的更多相关文章

  1. python核心编程第二版笔记

    python核心编程第二版笔记由网友提供:open168 python核心编程--笔记(很详细,建议收藏) 解释器options:1.1 –d   提供调试输出1.2 –O   生成优化的字节码(生成 ...

  2. 学习《Python核心编程》做一下知识点提要,方便复习(一)

    学习<Python核心编程>做一下知识点提要,方便复习. 计算机语言的本质是什么? a-z.A-Z.符号.数字等等组合成符合语法的字符串.供编译器.解释器翻译. 字母组合后产生各种变化拿p ...

  3. python核心编程--笔记

    python核心编程--笔记 的解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找pyt ...

  4. Python核心编程第二版(中文).pdf 目录整理

    python核心编程目录 Chapter1:欢迎来到python世界!-页码:7 1.1什么是python 1.2起源  :罗萨姆1989底创建python 1.3特点 1.3.1高级 1.3.2面向 ...

  5. python核心编程--笔记(不定时跟新)(转)

    的解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找python路径 1.4 –v   ...

  6. python核心编程笔记(转)

    解释器options: 1.1 –d   提供调试输出 1.2 –O   生成优化的字节码(生成.pyo文件) 1.3 –S   不导入site模块以在启动时查找python路径 1.4 –v   冗 ...

  7. Python核心编程(第二版)PDF

    Python核心编程(第二版) 目录 第1部分 Python核心第1章 欢迎来到Python世界1.1 什么是Python1.2 起源1.3 特点1.3.1 高级1.3.2 面向对象1.3.3 可升级 ...

  8. 拒绝从入门到放弃_《Python 核心编程 (第二版)》必读目录

    目录 目录 关于这本书 必看知识点 最后 关于这本书 <Python 核心编程 (第二版)>是一本 Python 编程的入门书,分为 Python 核心(其实并不核心,应该叫基础) 和 高 ...

  9. Python核心编程-描述符

    python中,什么描述符.描述符就是实现了"__get__"."__set__"或"__delete__" 方法中至少一个的对象.什么是非 ...

  10. Python核心编程的四大神兽:迭代器、生成器、闭包以及装饰器

      生成器 生成器是生成一个值的特殊函数,它具有这样的特点:第一次执行该函数时,先从头按顺序执行,在碰到yield关键字时该函数会暂停执行该函数后续的代码,并且返回一个值:在下一次调用该函数执行时,程 ...

随机推荐

  1. [小技巧]使用set对列表去重,并保持列表原来顺序

  2. 【Luogu】P3806点分治模板(点分治)

    题目链接 wc听不懂lca讲的高等数学专场(一个字都听不懂),然后就自学了点分治. 点分治就是我先处理完跟根有关的东西,然后把根标记掉,把原树拆成若干个联通块,然后分别对每个联通块(每个小树)搞一模一 ...

  3. HDU——1005Number Sequence(模版题 二维矩阵快速幂+操作符重载)

    Number Sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  4. BZOJ1226 [SDOI2009]学校食堂Dining 【状压dp】

    题目 小F 的学校在城市的一个偏僻角落,所有学生都只好在学校吃饭.学校有一个食堂,虽然简陋,但食堂大厨总能做出让同学们满意的菜肴.当然,不同的人口味也不一定相同,但每个人的口味都可以用一个非负整数表示 ...

  5. 学习 JSP:第二步 创建一个JSP Web Project

    接上文 学习 JSP:第一步Eclipse+Tomcat+jre(配置环境) [创建新工程](Dynamic Web Project) 1.选择 "File-->New-->Dy ...

  6. foj Problem 2275 Game

    Problem D Game Accept: 145    Submit: 844Time Limit: 1000 mSec    Memory Limit : 262144 KB Problem D ...

  7. FOJ Problem 2260 Card Game

                                                                                            Problem 2260 ...

  8. tyvj 2002 扑克牌

    期望DP 本题递推比较麻烦,可以记忆化搜索 注意搜索的边界条件 以及每一次转移 #include <iostream> #include <cstdio> #include & ...

  9. Promise简单实现--摘抄

    Promise 看了些promise的介绍,还是感觉不够深入,这个在解决异步问题上是一个很好的解决方案,所以详细看一下,顺便按照自己的思路实现一个简单的Promise. Promise/A+规范: 首 ...

  10. es6总结(九)--Iterator & for of