Python3入门(三)
三、Python3列表
序列是Python中最基本的数据结构。
-
序列中的每个值都有对应值的位置值,称之为索引,第一个索引是0,第二个索引是1,依次类推。
-
Python有6个序列的内置类型,但最常见的是列表和元组。
-
列表都可以进行的操作包括索引,切片,加,乘,检查成员。
-
Python已经内置确定序列的长度以及确定最大和最小元素的方法。
-
列表是最常用的Python数据类型,它可以作为一个方括号内的逗号分隔值出现。
-
列表的数据项不需要具有相同的数据类型。
list1 = ['Google', 'Runoob', 1997, 2000]
list2 = [1, 2, 3, 4, 5 ]
list3 = ["a", "b", "c", "d"]
list4 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
1.访问列表中的值
与字符串的索引一样,列表索引从0开始,第二个索引是1。
list = ['red', 'green', 'blue', 'yellow', 'white', 'black']
print( list[0] )
print( list[1] )
print( list[2] )
#输出结果:
#red
#green
#blue
索引也可以从尾部开始,最后一个元素的索引为**-1**,往前一位是**-2**。
list = ['red', 'green', 'blue', 'yellow', 'white', 'black']
print( list[-1] )
print( list[-2] )
print( list[-3] )
#输出结果:
#black
#white
#yellow
可以使用方括号 [] 的形式截取字符。
nums = [10, 20, 30, 40, 50, 60, 70, 80, 90]
print(nums[0:4])
#输出结果:
#[10, 20, 30, 40]
使用负数索引值截取:
list = ['Google', 'Runoob', "Zhihu", "Taobao", "Wiki"]
# 读取第二位
print ("list[1]: ", list[1])
# 从第二位开始(包含)截取到倒数第二位(不包含)
print ("list[1:-2]: ", list[1:-2])
输出结果:
#list[1]: Runoob
#list[1:-2]: ['Runoob', 'Zhihu']
2.更新列表
我们可以对列表的数据项进行修改或更新,也可以使用append() 方法来添加列表项。
list = ['Google', 'Runoob', 1997, 2000]
print ("第三个元素为 : ", list[2])
list[2] = 2001 #替换值
print ("更新后的第三个元素为 : ", list[2])
list1 = ['Google', 'Runoob', 'Taobao']
list1.append('Baidu') #在列表后插入
print ("更新后的列表 : ", list1)
#输出结果:
第三个元素为 : 1997
更新后的第三个元素为 : 2001
更新后的列表 : ['Google', 'Runoob', 'Taobao', 'Baidu']
3.删除列表元素
可以使用del语句来删除列表的元素。
list = ['Google', 'Runoob', 1997, 2000]
print ("原始列表 : ", list)
del list[2]
print ("删除第三个元素 : ", list)
list.remove(2000) #移除匹配的第一个元素
print(list)
#输出结果:
#原始列表 : ['Google', 'Runoob', 1997, 2000]
#删除第三个元素 : ['Google', 'Runoob', 2000]
#['Google', 'Runoob']
4.Python列表脚本操作符
列表对**+和*的操作符与字符串相似。+号用于组合列表,***号用于重复列表。
Python 表达式 | 结果 | 描述 |
---|---|---|
len([1, 2, 3]) | 3 | 长度 |
[1, 2, 3] + [4, 5, 6] | [1, 2, 3, 4, 5, 6] | 组合 |
[‘Hi!’] * 4 | [‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’] | 重复 |
3 in [1, 2, 3] | True | 元素是否存在于列表中 |
for x in [1, 2, 3]: print(x, end=" ") | 1 2 3 | 迭代 |
实例:
#统计列表长度
list1 = [1, 2, 3, 4, 5]
print(len(list1))
#输出结果:5
#列表组合
list2 = ['a', 'b', 'c']
print(list1 + list2)
#输出结果:[1, 2, 3, 4, 5, 'a', 'b', 'c']
#列表重复
print(list1 * 2)
#输出结果:[1, 2, 3, 4, 5, 1, 2, 3, 4, 5]
#判断元素是否存在于列表
a = 1
if a in list1:
print("a is in list")
else:
print("a is not in list")
#输出结果:a is in list
#列表迭代
for x in list1:
print(x, end=" ")
#输出结果:1 2 3 4 5
5.Python列表截取与拼接
Python的列表截取与字符串操作类型,如下所示:
L=['Google', 'Runoob', 'Taobao']
Python 表达式 | 结果 | 描述 |
---|---|---|
L[2] | ‘Taobao’ | 读取第三个元素 |
L[-2] | ‘Runoob’ | 从右侧开始读取倒数第二个元素: count from the right |
L[1:] | [‘Runoob’, ‘Taobao’] | 输出从第二个元素开始后的所有元素 |
6.嵌套列表
使用嵌套列表即在列表里创建其他列表,如:
a = ['a', 'b', 'c']
n = [1, 2, 3]
x = [a, n]
print(x)
print(x[0])
print(x[0][1])
#输出结果:
#[['a', 'b', 'c'], [1, 2, 3]]
#['a', 'b', 'c']
#b
7.Python列表函数&方法
Python包含以下函数:
序号 | 函数 |
---|---|
1 | len(list) 列表元素个数 |
2 | max(list) 返回列表元素最大值 |
3 | min(list) 返回列表元素最小值 |
4 | list(seq) 将元组转换为列表 |
Python包含以下方法:
序号 | 方法 |
---|---|
1 | list.append(obj) 在列表末尾添加新的对象 |
2 | list.count(obj) 统计某个元素在列表中出现的次数 |
3 | list.extend(seq) 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表) |
4 | list.index(obj) 从列表中找出某个值第一个匹配项的索引位置 |
5 | list.insert(index, obj) 将对象插入列表 |
6 | list.pop(index=-1) 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值 |
7 | list.remove(obj) 移除列表中某个值的第一个匹配项 |
8 | list.reverse() 反向列表中元素 |
9 | list.sort( key=None, reverse=False) 对原列表进行排序 |
10 | list.clear() 清空列表 |
11 | list.copy() 复制列表 |
四、Python3元组
-
Python的元组与列表类似,不同之处在于元组的元素不能修改。
-
元组使用小括号 ( ),列表使用方括号 [ ]。
-
元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可。
创建空元组
tup1 = ()
元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当做运算符使用:
tup1 = (50)
print(type(tup1)) # 不加逗号,类型为整型
tup1 = (50,)
print(type(tup1)) # 加上逗号,类型为元组
#输出结果:
#<class 'int'>
#<class 'tuple'>
元组与字符串类似,下标索引从0开始,可以进行截取,组合等。
1.访问元组
元组可以使用下标索引来访问元组中的值。
tup1 = ('Google', 'Runoob', 1997, 2000)
tup2 = (1, 2, 3, 4, 5, 6, 7 )
print ("tup1[0]: ", tup1[0])
print ("tup2[1:5]: ", tup2[1:5])
#输出结果:
#tup1[0]: Google
#tup2[1:5]: (2, 3, 4, 5)
2.修改元组
元组中的元素值是不允许修改的,但我们可以对元组进行组合连接。
tup1 = (12, 34.56)
tup2 = ('abc', 'xyz')
# 以下修改元组元素操作是非法的。
# tup1[0] = 100
# 创建一个新的元组
tup3 = tup1 + tup2
print (tup3)
#输出结果:(12, 34.56, 'abc', 'xyz')
3.删除元组
元组中的元素是不允许删除的,但可以使用del语句来删除整个元组。
tup = ('Google', 'Runoob', 1997, 2000)
print(tup)
del tup
print("删除后的元组 tup : ")
print(tup)
#输出结果:
#('Google', 'Runoob', 1997, 2000)
#删除后的元组 tup :
#Traceback (most recent call last):
# File "D:/python_project/main.py", line 6, in <module>
# print(tup)
#NameError: name 'tup' is not defined
4.元组运算符
与字符串一样,元组之间可以使用 + 号和 ***** 号进行运算。
Python 表达式 | 结果 | 描述 |
---|---|---|
len((1, 2, 3)) | 3 | 计算元素个数 |
(1, 2, 3) + (4, 5, 6) | (1, 2, 3, 4, 5, 6) | 连接 |
(‘Hi!’,) * 4 | (‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’) | 复制 |
3 in (1, 2, 3) | True | 元素是否存在 |
for x in (1, 2, 3): print (x,) | 1 2 3 | 迭代 |
5.元组索引、截取
因为元组也是一个序列,所以我们可以访问元组中的指定位置的元素,也可以截取索引中的一段元素。
tup = ('Google', 'Runoob', 'Taobao', 'Wiki', 'Weibo','Weixin')
Python 表达式 | 结果 | 描述 |
---|---|---|
tup[1] | ‘Runoob’ | 读取第二个元素 |
tup[-2] | ‘Weibo’ | 反向读取,读取倒数第二个元素 |
tup[1:] | (‘Runoob’, ‘Taobao’, ‘Wiki’, ‘Weibo’, ‘Weixin’) | 截取元素,从第二个开始后的所有元素。 |
tup[1:4] | (‘Runoob’, ‘Taobao’, ‘Wiki’) | 截取元素,从第二个开始到第四个元素(索引为 3)。 |
实例:
tup = ('Google', 'Runoob', 'Taobao', 'Wiki', 'Weibo','Weixin')
print(tup[1])
print(tup[-2])
print(tup[1:])
print(tup[1:4]) #不包括4
#输出结果:
#Runoob
#Weibo
#('Runoob', 'Taobao', 'Wiki', 'Weibo', 'Weixin')
#('Runoob', 'Taobao', 'Wiki')
6.元组内置函数
Python元组包含了以下内置函数
序号 | 方法及描述 | 实例 |
---|---|---|
1 | len(tuple) 计算元组元素个数。 | >>> tuple1 = ('Google', 'Runoob', 'Taobao') >>> len(tuple1) 3 >>> |
2 | max(tuple) 返回元组中元素最大值。 | >>> tuple2 = ('5', '4', '8') >>> max(tuple2) '8' >>> |
3 | min(tuple) 返回元组中元素最小值。 | >>> tuple2 = ('5', '4', '8') >>> min(tuple2) '4' >>> |
4 | tuple(iterable) 将可迭代系列转换为元组。 | >>> list1= ['Google', 'Taobao', 'Runoob', 'Baidu'] >>> tuple1=tuple(list1) >>> tuple1 ('Google', 'Taobao', 'Runoob', 'Baidu') |
关于元组是不可变的
所谓元组的不可变指的是元组所指向的内存中的内容不可变。
tup = ('r', 'u', 'n', 'o', 'o', 'b')
# tup[0] = 'g' # 不支持修改元素,会报错
print(id(tup)) # 查看内存地址
tup = (1, 2, 3)
print(id(tup)) # 内存地址不一样了
#输出结果:
#1939753868360
#1939754167416
五、Python3字典
-
字典是另一种可变容器模型,且可存储任意类型对象。
-
字典的每个键值 key=>value 对用冒号 : 分割,每个对之间用逗号(,)分割,整个字典包括在花括号 {} 中 ,格式如下所示:
d = {key1 : value1, key2 : value2, key3 : value3 }
键必须是唯一的,但值不必。
值可以取任何数据类型,但键必须是不可变的,如字符串,数字。
1.访问字典里的值
把相应的键放入方括号中:
dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
print ("dict['Name']: ", dict['Name'])
print ("dict['Age']: ", dict['Age'])
#输出结果:
#dict['Name']: Runoob
#dict['Age']: 7
#如果访问的值不在字典里,则会报错
print("dict['Alice']: ", dict['Alice'])
#Traceback (most recent call last):
# File "D:/python_project/main.py", line 5, in <module>
# print("dict['Alice']: ", dict['Alice'])
#KeyError: 'Alice'
2.修改字典
向字典里添加新内容的方法是增加新的键/值对,修改或删除已有键/值对。
dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
dict['Age'] = 8 # 更新 Age
dict['School'] = "菜鸟教程" # 添加信息
print("dict['Age']: ", dict['Age'])
print("dict['School']: ", dict['School'])
print(dict)
#输出结果:
#dict['Age']: 8
#dict['School']: 菜鸟教程
#{'Name': 'Runoob', 'Age': 8, 'Class': 'First', 'School': '菜鸟教程'}
3.删除字典元素
能删单一的元素也能清空字典,清空只需一项操作。
显示删除一个字典用del命令。
dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
del dict['Name'] # 删除键 'Name'
print ("dict['Age']: ", dict['Age'])
print(dict)
dict.clear() # 清空字典
print(dict)
del dict # 删除字典 删除后字典不存在,报错
#输出结果:
#dict['Age']: 7
#{'Age': 7, 'Class': 'First'}
#{}
字典键的特性
字典值可以是任何的Python对象,既可以是标准的对象,也可以是用户定义的,但键不行。
- 不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住。
dict = {'Name': 'Runoob', 'Age': 7, 'Name': 'lihua'}
print("dict['Name']: ", dict['Name'])
#输出结果:
#dict['Name']: lihua
- 键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行。
dict = {['Name']: 'Runoob', 'Age': 7}
print ("dict['Name']: ", dict['Name'])
#输出结果:
#Traceback (most recent call last):
# File "D:/python_project/main.py", line 1, in <module>
# dict = {['Name']: 'Runoob', 'Age': 7}
#TypeError: unhashable type: 'list'
4.字典内置函数&方法
Python字典包含了以下内置函数:
序号 | 函数及描述 | 实例 |
---|---|---|
1 | len(dict) 计算字典元素个数,即键的总数。 | >>> dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} >>> len(dict) 3 |
2 | str(dict) 输出字典,以可打印的字符串表示。 | >>> dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} >>> str(dict) "{'Name': 'Runoob', 'Class': 'First', 'Age': 7}" |
3 | type(variable) 返回输入的变量类型,如果变量是字典就返回字典类型。 | >>> dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} >>> type(dict) <class 'dict'> |
Python字典包含了以下内置方法:
序号 | 函数及描述 |
---|---|
1 | radiansdict.clear() 删除字典内所有元素 |
2 | radiansdict.copy() 返回一个字典的浅复制 |
3 | radiansdict.fromkeys() 创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值 |
4 | radiansdict.get(key, default=None) 返回指定键的值,如果键不在字典中返回 default 设置的默认值 |
5 | key in dict 如果键在字典dict里返回true,否则返回false |
6 | radiansdict.items() 以列表返回可遍历的(键, 值) 元组数组 |
7 | radiansdict.keys() 返回一个迭代器,可以使用 list() 来转换为列表 |
8 | radiansdict.setdefault(key, default=None) 和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default |
9 | radiansdict.update(dict2) 把字典dict2的键/值对更新到dict里 |
10 | radiansdict.values() 返回一个迭代器,可以使用 list() 来转换为列表 |
11 | pop(key,default) 删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。 |
12 | popitem() 随机返回并删除字典中的最后一对键和值。 |
实例:
#clear()方法
dict = {'Name': 'Zara', 'Age': 7}
print("字典长度 : %d" % len(dict))
dict.clear()
print("字典删除后长度 : %d" % len(dict))
print(dict)
#输出结果:
#字典长度 : 2
#字典删除后长度 : 0
#{}
#copy()方法
dict1 = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
dict2 = dict1.copy()
#浅拷贝:深拷贝父对象(一级目录),子对象(二级目录)不拷贝,子对象是引用
print ("dict2 : ",dict2)
dict3 = dict1 #浅拷贝:引用对象
print("dict3 : ",dict3)
#输出结果:
#dict2 : {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
#dict3 : {'Name': 'Runoob', 'Age': 7, 'Class': 'First'}
#fromkeys()方法
#seq -- 字典键值列表。
#value -- 可选参数, 设置键序列(seq)对应的值,默认为 None。
seq = ('name', 'age', 'sex')
dict = dict.fromkeys(seq)
print ("新的字典为 : %s" % str(dict))
dict = dict.fromkeys(seq, 10)
print ("新的字典为 : %s" % str(dict))
#输出结果:
新的字典为 : {'name': None, 'age': None, 'sex': None}
新的字典为 : {'name': 10, 'age': 10, 'sex': 10}
#get()方法
#key -- 字典中要查找的键。
#default -- 如果指定的键不存在时,返回该默认值。
dict = {'Name': 'Runoob', 'Age': 27}
print ("Age 值为 : %s" % dict.get('Age'))
print ("Sex 值为 : %s" % dict.get('Sex', "NA"))
#输出结果:
#Age 值为 : 27
#Sex 值为 : NA
#items()方法
dict = {'Name': 'Runoob', 'Age': 7}
print ("Value : %s" % dict.items())
#输出结果:
#Value : dict_items([('Name', 'Runoob'), ('Age', 7)])
#keys()方法
dict = {'Name': 'Runoob', 'Age': 7}
print(dict.keys())
print(list(dict.keys())) # 转换为列表
#输出结果:
#dict_keys(['Name', 'Age'])
#['Name', 'Age']
六、Python3集合
集合(set)是一个无序的不重复元素序列。
可以使用大括号**{ }** 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
parame = {value01,value02,...}
或者
set(value)
实例:
basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
print(basket) # 这里演示的是去重功能
if 'orange' in basket: # 快速判断元素是否在集合内
print("Ture")
else:
print("False")
if 'crabgrass' in basket:
print("Ture")
else:
print("False")
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的元素
#输出结果:
#{'orange', 'apple', 'pear', 'banana'}
#Ture
#False
#{'a', 'r', 'd', 'c', 'b'}
#{'r', 'b', 'd'}
#{'a', 'z', 'r', 'd', 'm', 'l', 'c', 'b'}
#{'c', 'a'}
#{'d', 'l', 'z', 'b', 'r', 'm'}
集合的基本操作
1.添加元素
语法格式如下:
s.add( x ) #将元素x添加到集合s中,如果元素已存在,则不进行任何操作
s.update( x ) #添加元素,且参数可以是列表,元组,字典等
实例:
thisset = set(("Google", "Runoob", "Taobao"))
thisset.add("Facebook")
print(thisset)
thisset.update({1,3})
print(thisset)
thisset.update([1,4],[5,6])
print(thisset)
#运行结果:
#{'Runoob', 'Google', 'Facebook', 'Taobao'}
#{1, 'Google', 3, 'Taobao', 'Runoob', 'Facebook'}
#{1, 3, 4, 5, 6, 'Facebook', 'Google', 'Runoob', 'Taobao'}
2.移除元素
语法格式如下:
s.remove( x ) #将元素 x 从集合 s 中移除,如果元素不存在,则会发生错误。
s.discard( x ) #移除集合中的元素,且如果元素不存在,不会发生错误。
s.pop() #随机删除集合中的一个元素(set 集合的 pop 方法会对集合进行无序的排列,然后将这个无序排列集合的左面第一个元素进行删除。)
实例:
thisset = set(("Google", "Runoob", "Taobao"))
thisset.remove("Taobao")
print(thisset
thisset.remove("Facebook") # 不存在会发生错误
thisset.discard("Facebook") # 不存在不会发生错误
print(thisset)
thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
x = thisset.pop()
print(x)
#输出结果:
#{'Google', 'Runoob'}
#Traceback (most recent call last):
# File "D:/python_project/main.py", line 4, in <module>
# thisset.remove("Facebook") # 不存在会发生错误
#KeyError: 'Facebook'
#{'Runoob', 'Google'}
#Runoob 多次运行结果都不一样
3.计算集合元素个数
语法格式如下:
len(s) #计算结合S元素个数
实例:
thisset = set(("Google", "Runoob", "Taobao"))
print(len(thisset))
#输出结果:
#3
4.清空格式
语法格式如下:
s.clear() #清空集合 s
实例:
thisset = set(("Google", "Runoob", "Taobao"))
thisset.clear()
print(thisset)
#输出结果:
#set()
5.判断元素是否在集合中
语法格式如下:
x in s #判断元素 x 是否在集合 s 中,存在返回 True,不存在返回 False。
实例:
thisset = set(("Google", "Runoob", "Taobao"))
if "Runoob" in thisset:
print("Ture")
else:
print("False")
if "Facebook" in thisset:
print("Ture")
else:
print("False")
#输出结果:
#Ture
#False
集合内置方法完整列表
方法 | 描述 |
---|---|
add() | 为集合添加元素 |
clear() | 移除集合中的所有元素 |
copy() | 拷贝一个集合 |
difference() | 返回多个集合的差集 |
difference_update() | 移除集合中的元素,该元素在指定的集合也存在。 |
discard() | 删除集合中指定的元素 |
intersection() | 返回集合的交集 |
intersection_update() | 返回集合的交集。 |
isdisjoint() | 判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。 |
issubset() | 判断指定集合是否为该方法参数集合的子集。 |
issuperset() | 判断该方法的参数集合是否为指定集合的子集 |
pop() | 随机移除元素 |
remove() | 移除指定元素 |
symmetric_difference() | 返回两个集合中不重复的元素集合。 |
symmetric_difference_update() | 移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。 |
union() | 返回两个集合的并集 |
update() | 给集合添加元素 |