Python3基础之基本数据类型概述

(编辑:jimmy 日期: 2024/11/21 浏览:2)

本文针对Python3中基本数据类型进行实例介绍,这些对于Python初学者而言是必须掌握的知识,具体内容如下:

首先,Python中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。在Python中,变量就是变量,它没有类型,我们所说的“类型”是变量所指的内存中对象的类型。Python 3中有六个标准的数据类型:

Numbers(数字)

String(字符串)

List(列表)

Tuple(元组)

Sets(集合)

Dictionaries(字典)

本文主要先介绍这几种数据类型的定义和它们之间的联系与区别。

一、Numbers

Python 3支持int、float、bool、complex(复数)。数值类型的赋值和计算都是很直观的,就像大多数语言一样。内置的type()函数可以用来查询变量所指的对象类型。

> a, b, c, d = 20, 5.5, True, 4+3j
> print(type(a), type(b), type(c), type(d))
<class 'int'> <class 'float'> <class 'bool'> <class 'complex'>

数值运算:

> 5 + 4 # 加法
9
> 4.3 - 2 # 减法
2.3
> 3 * 7 # 乘法
21
> 2 / 4 # 除法,得到一个浮点数
0.5
> 2 // 4 # 除法,得到一个整数
0
> 17 % 3 # 取余 
2
> 2 ** 5 # 乘方
32

要点:

1、Python可以同时为多个变量赋值,如a, b = 1, 2。
2、一个变量通过赋值可以指向不同类型的对象。
3、数值的除法(/)总是返回一个浮点数,要获取整数使用//操作符。
4、在混合计算时,Pyhton会把整型转换成为浮点数。

二、Strings

Python中的字符串str用单引号(‘ ')或双引号(“ ”)括起来,同时使用反斜杠(\)转义特殊字符。

> s = 'Yes,he doesn\'t'
> print(s, type(s), len(s))
Yes,he doesn't <class 'str'> 14

如果你不想让反斜杠发生转义,可以在字符串前面添加一个r,表示原始字符串:

> print('C:\some\name')
C:\some
ame
> print(r'C:\some\name')
C:\some\name

另外,反斜杠可以作为续行符,表示下一行是上一行的延续。还可以使用"""..."""或者'''...'''跨越多行。

字符串可以使用 + 运算符串连接在一起,或者用 * 运算符重复:

> print('str'+'ing', 'my'*3)
string mymymy

Python中的字符串有两种索引方式,第一种是从左往右,从0开始依次增加;第二种是从右往左,从-1开始依次减少。注意,没有单独的字符类型,一个字符就是长度为1的字符串。

> word = 'Python'
> print(word[0], word[5])
P n
> print(word[-1], word[-6])
n P

还可以对字符串进行切片,获取一段子串。用冒号分隔两个索引,形式为变量[头下标:尾下标]。截取的范围是前闭后开的,并且两个索引都可以省略:

> word = 'ilovepython'
> word[1:5]
'love'
> word[:]
'ilovepython'
> word[5:]
'python'
> word[-10:-6]
'love'

与C字符串不同的是,Python字符串不能被改变。向一个索引位置赋值,比如word[0] = 'm'会导致错误。

要点:

1、反斜杠可以用来转义,使用r可以让反斜杠不发生转义。
2、字符串可以用+运算符连接在一起,用*运算符重复。
3、Python中的字符串有两种索引方式,从左往右以0开始,从右往左以-1开始。
4、Python中的字符串不能改变。

三、List

List(列表) 是 Python 中使用最频繁的数据类型。列表是写在方括号之间、用逗号分隔开的元素列表。列表中元素的类型可以不相同:

> a = ['him', 25, 100, 'her'] 
> print(a, type(a), len(a))
['him', 25, 100, 'her'] <class 'list'> 4

和字符串一样,列表同样可以被索引和切片,列表被切片后返回一个包含所需元素的新列表。详细的在这里就不赘述了。

列表还支持串联操作,使用+操作符:

> a = [1, 2, 3, 4, 5]
> a + [6, 7, 8]
[1, 2, 3, 4, 5, 6, 7, 8]

与Python字符串不同的是,列表中的元素是可以改变的:

> a = [1, 2, 3, 4, 5, 6]
> a[0] = 9
> a[2:5] = [13, 14, 15]
> a
[9, 2, 13, 14, 15, 6]
> a[2:5] = []  # 删除
> a
[9, 2, 6]

List内置了有很多方法,例如append()、pop()等等,这在后面会讲到。

要点:

1、List写在方括号之间,元素用逗号隔开。
2、和字符串一样,list可以被索引和切片。
3、List可以使用+操作符进行拼接。
4、List中的元素是可以改变的。

四、Tuple

元组(tuple)与列表类似,不同之处在于元组的元素不能修改。元组是写在小括号之间、用逗号隔开的元素列表。元组中的元素类型也可以不相同:

> a = (1991, 2014, 'physics', 'math')
> print(a, type(a), len(a))
(1991, 2014, 'physics', 'math') <class 'tuple'> 4

元组与字符串类似,可以被索引且下标索引从0开始,也可以进行截取/切片(看上面,这里不再赘述)。其实,可以把字符串看作一种特殊的元组。

> tup = (1, 2, 3, 4, 5, 6)
> print(tup[0], tup[1:5])
1 (2, 3, 4, 5)
> tup[0] = 11 # 修改元组元素的操作是非法的

虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。
构造包含0个或1个元素的tuple是个特殊的问题,所以有一些额外的语法规则:

tup1 = () # 空元组
tup2 = (20,) # 一个元素,需要在元素后添加逗号

另外,元组也支持用+操作符:

> tup1, tup2 = (1, 2, 3), (4, 5, 6)
> print(tup1+tup2)
(1, 2, 3, 4, 5, 6)

string、list和tuple都属于sequence(序列)。

要点:

1、与字符串一样,元组的元素不能修改。
2、元组也可以被索引和切片,方法一样。
3、注意构造包含0或1个元素的元组的特殊语法规则。
4、元组也可以使用+操作符进行拼接。

五、Sets

集合(set)是一个无序不重复元素的集。基本功能是进行成员关系测试和消除重复元素。可以使用大括号或者set()函数创建set集合,注意:创建一个空集合必须用 set() 而不是 { },因为{ }是用来创建一个空字典。

> student = {'Tom', 'Jim', 'Mary', 'Tom', 'Jack', 'Rose'}
> print(student)  # 重复的元素被自动去掉
{'Jim', 'Jack', 'Mary', 'Tom', 'Rose'}
> 'Rose' in student # membership testing(成员测试)
True
> # set可以进行集合运算
... 
> a = set('abracadabra')
> b = set('alacazam')
> a
{'a', 'b', 'c', 'd', 'r'}
> a - b   # a和b的差集
{'b', 'd', 'r'}
> a | b   # a和b的并集
{'l', 'm', 'a', 'b', 'c', 'd', 'z', 'r'}
> a & b   # a和b的交集
{'a', 'c'}
> a ^ b   # a和b中不同时存在的元素
{'l', 'm', 'b', 'd', 'z', 'r'}

要点:

1、set集合中的元素不重复,重复了它会自动去掉。
2、set集合可以用大括号或者set()函数创建,但空集合必须使用set()函数创建。
3、set集合可以用来进行成员测试、消除重复元素。

六、Dictionaries

字典(dictionary)是Python中另一个非常有用的内置数据类型。字典是一种映射类型(mapping type),它是一个无序的键 : 值对集合。关键字必须使用不可变类型,也就是说list和包含可变类型的tuple不能做关键字。在同一个字典中,关键字还必须互不相同。

> dic = {} # 创建空字典
> tel = {'Jack':1557, 'Tom':1320, 'Rose':1886}
> tel
{'Tom': 1320, 'Jack': 1557, 'Rose': 1886}
> tel['Jack']  # 主要的操作:通过key查询
1557
> del tel['Rose'] # 删除一个键值对
> tel['Mary'] = 4127 # 添加一个键值对
> tel
{'Tom': 1320, 'Jack': 1557, 'Mary': 4127}
> list(tel.keys()) # 返回所有key组成的list
['Tom', 'Jack', 'Mary']
> sorted(tel.keys()) # 按key排序
['Jack', 'Mary', 'Tom']
> 'Tom' in tel    # 成员测试
True
> 'Mary' not in tel # 成员测试
False

构造函数 dict() 直接从键值对sequence中构建字典,当然也可以进行推导,如下:

> dict([('sape', 4139), ('guido', 4127), ('jack', 4098)])
{'jack': 4098, 'sape': 4139, 'guido': 4127}

> {x: x**2 for x in (2, 4, 6)}
{2: 4, 4: 16, 6: 36}

> dict(sape=4139, guido=4127, jack=4098)
{'jack': 4098, 'sape': 4139, 'guido': 4127}

另外,字典类型也有一些内置的函数,例如clear()、keys()、values()等。

要点:

1、字典是一种映射类型,它的元素是键值对。
2、字典的关键字必须为不可变类型,且不能重复。
3、创建空字典使用{ }。

一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。