数据类型
Number(数字)
在day02中有讲过数字类型
Python中有四种数据类型
整数、浮点数、布尔数、复数
( int、float、bool、complex)
在Python2及其他语言中有长整型(long)的概念
不过在Python3中不论长短统一称为整型(int)
像大多数语言一样,数值类型的赋值和计算都是很直观的。
判断类型
判断变量的值是何种数字类型的方法:
1.type(变量名)
a, b, c, d = 20, 5.5, True, 4+3j
print(type(a), type(b), type©, type(d))
<class ‘int’> <class ‘float’> <class ‘bool’> <class ‘complex’>
2.isinstance(变量名, 某种数据类型名称)
如果变量的值是该数据类型
显示结果True
a = 111
isinstance(a, int)
True
运算方法
5 + 4 # 加法
94.3 - 2 # 减法
2.33 * 7 # 乘法
212 / 4 # 除法,得到一个浮点数
0.52 // 4 # 除法,得到一个整数
017 % 3 # 取余
22 ** 5 # 乘方
32
注意
1.除法中/ 返回一个浮点数,// 返回一个整数。(返回整数的意思不是四舍五入,是仅仅保留该数的整数部分)
2.在混合计算时,Python会把整型转换成为浮点数。
List(列表)
列表可以完成大多数集合类的数据结构实现。列表中元素的类型可以不相同,它支持数字,字符串甚至可以包含列表(所谓嵌套,老千层饼了)(关于列表中能不能有元组和集合,不清楚,区别不是很大,能有列表应该也能有元组集合字典,也没查到)。
列表的建立:
列表是写在方括号 [] 之间、用逗号分隔开的元素列表。
列表中的字符串元素也要在冒号’'之间
列表索引截取
加号 + 是列表连接运算符,星号 * 是重复操作。如下实例:
#!/usr/bin/python3
list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ]
tinylist = [123, 'runoob']
print (list) # 输出完整列表
print (list[0]) # 输出列表第一个元素
print (list[1:3]) # 从第二个开始输出到第三个元素
print (list[2:]) # 输出从第三个元素开始的所有元素
print (tinylist * 2) # 输出两次列表
print (list + tinylist) # 连接列表
输出结果为
[‘abcd’, 786, 2.23, ‘runoob’, 70.2]
abcd
[786, 2.23]
[2.23, ‘runoob’, 70.2]
[123, ‘runoob’, 123, ‘runoob’]
[‘abcd’, 786, 2.23, ‘runoob’, 70.2, 123, ‘runoob’]
列表中的元素是可以改变的,但不可以改变列表中的字符串
>>> 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]
Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:
如果第三个参数为负数表示逆向读取,以下实例用于翻转字符串:
def reverseWords(input):
# 通过空格将字符串分隔符,把各个单词分隔为列表
inputWords = input.split(" ")
# 翻转字符串
# 假设列表 list = [1,2,3,4],
# list[0]=1, list[1]=2 ,而 -1 表示最后一个元素 list[-1]=4 ( 与 list[3]=4 一样)
# inputWords[-1::-1] 有三个参数
# 第一个参数 -1 表示最后一个元素
# 第二个参数为空,表示移动到列表末尾
# 第三个参数为步长,-1 表示逆向
inputWords=inputWords[-1::-1]
# 重新组合字符串
output = ' '.join(inputWords)
return output
if __name__ == "__main__":
input = 'I like runoob'
rw = reverseWords(input)
print(rw)
输出结果为
runoob like I
Tuple(元组)
与列表相似
不同之处:元素不能更改(但是可以包含能更改的元素,例如列表)
建立方法:用小括号(),元素放在小括号中,用逗号隔开,元素的数据类型可以不同
元组索引截取方法和列表相同
构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则:
tup1 = () # 空元组
tup2 = (20,) # 一个元素,需要在元素后添加逗号
列表中可以有元祖吗
string、list 和 tuple 都属于 sequence(序列)。
Set(集合)
集合(set)是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员。
基本功能是进行成员关系测试和删除重复元素
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
parame = {value01,value02,…}
或者
set(value)
一些集合的操作方法
#!/usr/bin/python3
sites = {'Google', 'Taobao', 'Runoob', 'Facebook', 'Zhihu', 'Baidu'}
print(sites) # 输出集合,重复的元素被自动去掉
# 成员测试
if 'Runoob' in sites :
print('Runoob 在集合中')
else :
print('Runoob 不在集合中')
# set可以进行集合运算
a = set('abracadabra')
b = set('alacazam')
print(a)
print(a - b) # a 和 b 的差集
print(a | b) # a 和 b 的并集
print(a & b) # a 和 b 的交集
print(a ^ b) # a 和 b 中不同时存在的元素
输出结果为
{‘Zhihu’, ‘Baidu’, ‘Taobao’, ‘Runoob’, ‘Google’, ‘Facebook’}
Runoob 在集合中
{‘b’, ‘c’, ‘a’, ‘r’, ‘d’}
{‘r’, ‘b’, ‘d’}
{‘b’, ‘c’, ‘a’, ‘z’, ‘m’, ‘r’, ‘l’, ‘d’}
{‘c’, ‘a’}
{‘z’, ‘b’, ‘m’, ‘r’, ‘l’, ‘d’}
Dictionary(字典)
列表有序,字典无序
两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。
字典是一种映射类型,字典用 { } 标识,它是一个无序的 键(key) : 值(value) 的集合。
键(key)必须使用不可变类型。
在同一个字典中,键(key)必须是唯一的。
#!/usr/bin/python3
dict = {}
dict['one'] = "1 - 菜鸟教程"
dict[2] = "2 - 菜鸟工具"
tinydict = {'name': 'runoob','code':1, 'site': 'www.runoob.com'}
print (dict['one']) # 输出键为 'one' 的值
print (dict[2]) # 输出键为 2 的值
print (tinydict) # 输出完整的字典
print (tinydict.keys()) # 输出所有键
print (tinydict.values()) # 输出所有值
输出结果为:
1 - 菜鸟教程
2 - 菜鸟工具
{‘name’: ‘runoob’, ‘code’: 1, ‘site’: ‘www.runoob.com’}
dict_keys([‘name’, ‘code’, ‘site’])
dict_values([‘runoob’, 1, ‘www.runoob.com’])
构造函数 dict() 可以直接从键值对序列中构建字典如下:
实例
dict([(‘Runoob’, 1), (‘Google’, 2), (‘Taobao’, 3)])
{‘Runoob’: 1, ‘Google’: 2, ‘Taobao’: 3}{x: x**2 for x in (2, 4, 6)}
{2: 4, 4: 16, 6: 36}dict(Runoob=1, Google=2, Taobao=3)
{‘Runoob’: 1, ‘Google’: 2, ‘Taobao’: 3}
另外,字典类型也有一些内置的函数,例如clear()、keys()、values()等。
问题
字典中键是啥
列表中能不能包含字典集合元组
集合中的元素是不是一定要是同种数据类型