Python基础之数据类型详解

一、整数

python2中整形可以分为一般整形和长整形,但是在python3中,两者以及合二为一了,只有整形。python中的整形是具有无限精度的(只有内存能放下),可以表示任意位数的数字。例如:

>>> 1111_2222_3333_4444_5555_6666_7777_8888_9999_0000
1111222233334444555566667777888899990000

python人性化的地方在于,上面的代码中,我每四位做了一个分割,让数字看起来很清晰。外国人可能更喜欢每3位做一个分割。

>>> 123_456_789
123456789
>>>

二、浮点数

浮点数在CPython中的标准实现是采用C语言中的双精度类型(double)来实现,因此一个浮点数占8字节,这点对于python而言可能不重要。重要的是它是按照IEEE754标准实现的。例如:

>>> 1.234
1.234
>>> 1.23412313131231233
1.2341231313123124
>>> 1.231123E100
1.231123e+100

浮点数支持科学计数法写法。

三、复数

python内部集成了复数类型,这对于坐标或者复变函数与积分变换计算而言可能提供了大大的方便,但是通常处理数值计算的时候,我们还是采用numpy库。复数可以直接用1+1j类似的方式来直接初始化,也可以使用内建函数complex(real,imag)来创建一个复数。例如:

>>> a = 1+2j
>>> a
(1+2j)
>>> type(a)
<class 'complex'>
>>> b = complex(2,2)
>>> b
(2+2j)
>>> 

当然了,python也提供了复数相关计算的实现,例如:

>>> b + a
(3+4j)
>>> a - b
(-1+0j)
>>> a * b
(-2+6j)
>>> a / b
(0.75+0.25j)
>>> 

四、运算符,优先级以及结合性

每一门语言都有自己所支持的运算符,运算符之间是有优先级的,操作数和运算符之间是由结合性的。一般而言,我们没有必要清楚的记住每一个运算符直接的关系。这就要求在编写程序的时候,多使用()来表达表达式的精确意义。例如:

>>> x = 1
>>> y = 2
>>> not x and y or y > x != 1
False

这样的表达式就已经过于复杂了,不太好理解其中的逻辑。当然了,你的真实意图可能如下:

>>> ((not x) and y) or (y > (x != 1))
True

这时候,结果就和上面的不一样了,所以如果没有必要,不要写复杂表达式,如果写了,那么请给复杂表达式加上()来精确的表达你的意思。

五、混合类型计算

混合类型之间的计算结果总是向复杂的类型转换。例如:

>>> num = 1 + 2.3
>>> type(num)
<class 'float'>
>>> num =  1 + (2 + 3j)
>>> type(num)
<class 'complex'>

六、除法

在python3中除法可以分为正常除法和取整除法两种。由于python2已经停止了支持,本专栏的所有内容将只针对python3。
/:现在python3中的/总是执行真除法,无论操作数的类型是什么。执行结果总是包含小数部分。
//:执行向下取整除法,如果操作数都是整数,那么结果将会是整数;如果其中任意一个操作数是浮点数,那么执行结果将会是浮点数。
仔细看下面的例子:

>>> 3 / 2
1.5
>>> 3.0 / 2
1.5
>>> 3 // 2
1
>>> 3.0 // 2
1.0

尽管,我们可能很少书写包含最后一种情形的表达式,但是我们需要注意它的结果,它仍旧是先执行向下取整除法,然后加上小数部分。再来看下面的例子,来证实这确实是向下取整除法

>>> -2.9 // 1
-3.0
>>> -2.1 // 1
-3.0

七、十进制,八进制,十六进制和二进制

python中默认字面值是10进制,也可以使用下面的方式来产生其它进制的字面值

>>> 0o12    # 8进制
10
>>> 0xA     # 16进制
10
>>> 0b10    # 2进制
2

它们都是以0开头,8进制跟字母o(大小写都可以),16进制跟字母x,2进制跟字母b;之后跟上数值部分即可。当然了,python也提供了相应的函数来完成进制直接的相互转换。

>>> a = 3
>>> oct(a)      # 转成8进制字符串
'0o3'
>>> hex(a)      # 转成16进制字符串
'0x3'
>>> bin(a)      # 转成2进制字符串
'0b11'
>>> int('0b10',2)       # 将2进制转为10进制
2
>>> int('0xa',16)       # 将16进制  转为10进制
10
>>> int('0o12',8)       # 将8进制   转为10进制
10

int()函数(其实不是函数)用于将一个字符串或数字转换为整型。该函数的用法如下:

int(x, base=10)

x是数值字符串,base是该数值字符串的进制,base拥有一个默认值10.
python中还有另外一个函数eval(),该函数将其中的字符串当做python代码来执行,因此,它的效果如下:

>>> eval('0o12')
10
>>> eval('0xa')
10
>>> eval('0b10')
2

该函数运行的比较慢,因为他会将字符串作为程序的一个片段编译运行,所以该函数使用的时候实际上存在着比较大的安全风险。

八、位操作

python也支持C语言的位操作,但是在大多数时候,我们是用不到的。下表是位操作运算符。

位运算符 功能
<< 按位左移
>> 按位右移
| 按位或
& 按位与
^ 按位异或
~ 按位取反

其中值得一提的是,按位左移多少位就相当于给原数字乘上2的N次方,同理按位右移多少位就相当于给原数字除以2的N次方。在python中几乎是不会用到位运算的。

九、集合

python中的集合也是数值类型,集合提供了朴素集合论中集合的基本功能。满足确定性,互异性,无序性。需要特别注意的是,集合只包含不可变对象(可哈希的)类型,列表和字典是不能嵌入其中的,元组是可以的。但是集合本身是可变对象。关于集合的运算可以阅读集合论相关知识。
下面的例子展示集合中的元素只能是不可变对象,但是集合本身是可变对象。

>>> a.add(1)
>>> a
{1}
>>> a.add("123")
>>> a
{'123', 1}
>>> b =  1,2
>>> a.add(b)
>>> a
{'123', 1, (1, 2)}

集合中添加数字,字符串,元组等不可变对象是没有问题的。下面看一下添加可变对象会发生什么。

>>> c = [1,2,3]
>>> a.add(c)
Traceback (most recent call last)   :
  File "<stdin>", line 1, in    <module>
TypeError: unhashable type:     'list'
>>> d = {'1':1,'2':2}
>>> a.add(d)
Traceback (most recent call last)   :
  File "<stdin>", line 1, in    <module>
TypeError: unhashable type:     'dict'
>>> e = set()
>>> a.add(e)
Traceback (most recent call last)   :
  File "<stdin>", line 1, in    <module>
TypeError: unhashable type: 'set'

可以看到,无论是list,dict,set哪一个,都会提示类型错误,不可哈希类型。

十、布尔类型

python提供了显示的布尔类型,True和False是预置的两个布尔值。实际上,True和False是bool的两个实例,而bool只是内置类型int的子类。True和False的行为和1,0一致。bool为True和False重新定义了str和repr的字符串格式,所有打印出来就会显示True和False,而不是1,0.
有意思的是python制定了1,0两种情况下的显示,没有定义其余值的显示。所以显示的时候会发生下面的情况。

>>> True + 1
2

十一、其他数值类型

小数和分数类型都需要导入模块来创建,在这里不做过多的介绍。它们相比于浮点数而言,是精确的。尤其是当你需要高精度计算的时候,这就十分有必要了,通常大多数场合下,我们都不怎么需要它们。

>>> from decimal import Decimal
>>> a = Decimal('0.1')
>>> a
Decimal('0.1')
>>> from fractions import Fraction
>>> b = Fraction(1,3)                       # 1是分子,3是分母
>>> b
Fraction(1, 3)

到此这篇关于Python基础之数值类型详解的文章就介绍到这了,更多相关Python数值类型内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python变量及数据类型用法原理汇总

    变量(Variable)可以看成一个小箱子,专门用来"盛装"程序中的数据.每个变量都拥有独一无二的名字,通过变量的名字就能找到变量中的数据. 从底层看,程序中的数据最终都要放到内存中,变量其实就是这块内存的名字. 1. Python变量的赋值 在编程语言中,将数据放入变量的过程叫做赋值(Assignment).每个变量在使用前都必须赋值,变量赋值以后,该变量才会被创建. Python 使用等号=作为赋值运算符,具体格式为: name = value # name 表示变量名,value

  • Python xml、字典、json、类四种数据类型如何实现互相转换

    之前都是直接拿sax,或dom等库去解析xml文件为Python的数据类型再去操作,比较繁琐,如今在写Django网站ajax操作时json的解析,发现这篇帖子对这几种数据类型的转换操作提供了另一种更简洁的方法,xmltodict和 dicttoxml等库功不可没,几种转换方式也都比较全面,转存一下以备不时之需,感谢原创整理! 注:xml.字典.json.类四种数据的转换,从左到右依次转换,即xml要转换为类时,先将xml转换为字典,再将字典转换为json, 最后将json转换为类. 1.解析x

  • Python基础之数据类型知识汇总

    一.数字类型 1.整型int 就是整数 :100 ,200,2,3,4······· 2.浮点型 float 小数:1.22,1.32,1.00······ 3.内置函数--type type(已经被赋值的变量名或变量) count=100 print(type(count)) print(type(1.14)) 二.字符串类型 1.什么是字符串: (1)你在书上看到的都是字符串. (2)字符串用' '或者" "包裹起来 (3)字符串中可以包含任意字符:如字母,数字,符号且没有先后顺序

  • python中必会的四大高级数据类型(字符,元组,列表,字典)

    一. 字符串 生活中我们经常坐大巴车,每个座位一个编号,一个位置对应一个下标. 字符串中也有下标,要取出字符串中的部分数据,可以用下标取. python中使用切片来截取字符串其中的一段内容,切片截取的内容不包含结束下标对应的数据. 切片使用语法:[起始下标:结束下标:步长] ,步长指的是隔几个下标获取一个字符. 注意:下标会越界,切片不会 常用函数 练习: Test='rodma ' print(type(Test)) print('Test的一个字符串%s'%Test[0])#跟数组差不多 #

  • python数据类型可变不可变知识点总结

    python的数据类型可变不可变 1.什么是可变不可变 首先说一下什么是Python数据的可变不可变. 我们都知道定义变量的时候,是先创建一块内存空间,将值放进去,然后变量名里存放着该内存空间的内存地址.现在我们就可以解释了. 可变类型:就是这个数据类型的值在不改变这一块内存空间,而去改变这个数据类型的值. 不可变类型:当改变值得时候,会申请一块新的内存空间,不再是原来的那一块内存空间了. 2.不可变类型 数据类型中,有哪些是不可变类型呢? 在Python设计中,整数.浮点型.字符串.元祖都是不

  • python数据类型强制转换实例详解

    1.字符强转一切 如果是字符串进行强制转换, 仅仅就是在原数据类型的两边套上引号 2.list : 强制转换成列表 """ 如果是字符串,会把每一个字符都单独作为一个元素放到新的列表中 如果是字典,只保留键,形成一套新的列表. 如果是其他容器,只是单纯的在原数据的两边套上[] """ res = list(tuplevar) res = list(setvar) res = list(strvar) res = list(dictvar) # 把

  • 深入理解Python变量的数据类型和存储

      我们知道,python的变量是有类型的,对于python变量的几种数据类型,我们在写python时是必须要有一定的概念的.知道数据类型就要知道变量数据类型怎么存储,可是为什么python的变量不需要声明数据类型就可以直接赋值?变量如果有数据类型,那变量不是可以为任意数据类型?那真正的数据类型如int在内存存储的字节大小应该为多少?等等诸如一系列的问题让我提起了的兴趣,经过网上不断查找学习后,在此将我所了解到的内容在此做个总结归纳 一.变量的数据类型 1.什么是变量的数据类型   我们先捋一捋

  • Python 分布式缓存之Reids数据类型操作详解

    1.Redis API 1.安装redis模块 $ pip3.8 install redis 2.使用redis模块 import redis # 连接redis的ip地址/主机名,port,password=None r = redis.Redis(host="127.0.0.1",port=6379,password="gs123456") 3.redis连接池 redis-py使用connection pool来管理对一个redis server的所有连接,避

  • Python如何将函数值赋给变量

    本博文的知识点一个是模块的调用和一个自定义函数返回值赋值给变量 编写一个简单的函数模块: [root@bigdata zw]# more d.py #!/usr/bin/python # -*- coding:utf-8 -*- def run(name): list1 = 'hello ' + name return list1 编写一个调用的脚本: [root@bigdata zw]# more test.py import sys import os reload(sys) sys.set

  • python中关于数据类型的学习笔记

    数据类型是每种编程语言必备属性,只有给数据赋予明确的数据类型,计算机才能对数据进行处理运算,因此,正确使用数据类型是十分必要的,不同的语言,数据类型类似,但具体表示方法有所不同,以下是Python编程常用的数据类型: 1. 数字类型 Python数字类型主要包括int(整型).long(长整型)和float(浮点型),但是在Python3中就不再有long类型了. int(整型) 在32位机器上,整数的位数是32位,取值范围是-231~231-1,即-2147483648~214748364:在

随机推荐