Python3入门(三)

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包含以下函数:

序号函数
1len(list) 列表元素个数
2max(list) 返回列表元素最大值
3min(list) 返回列表元素最小值
4list(seq) 将元组转换为列表

Python包含以下方法:

序号方法
1list.append(obj) 在列表末尾添加新的对象
2list.count(obj) 统计某个元素在列表中出现的次数
3list.extend(seq) 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
4list.index(obj) 从列表中找出某个值第一个匹配项的索引位置
5list.insert(index, obj) 将对象插入列表
6list.pop(index=-1) 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
7list.remove(obj) 移除列表中某个值的第一个匹配项
8list.reverse() 反向列表中元素
9list.sort( key=None, reverse=False) 对原列表进行排序
10list.clear() 清空列表
11list.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元组包含了以下内置函数

序号方法及描述实例
1len(tuple) 计算元组元素个数。>>> tuple1 = ('Google', 'Runoob', 'Taobao') >>> len(tuple1) 3 >>>
2max(tuple) 返回元组中元素最大值。>>> tuple2 = ('5', '4', '8') >>> max(tuple2) '8' >>>
3min(tuple) 返回元组中元素最小值。>>> tuple2 = ('5', '4', '8') >>> min(tuple2) '4' >>>
4tuple(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字典包含了以下内置函数:

序号函数及描述实例
1len(dict) 计算字典元素个数,即键的总数。>>> dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} >>> len(dict) 3
2str(dict) 输出字典,以可打印的字符串表示。>>> dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} >>> str(dict) "{'Name': 'Runoob', 'Class': 'First', 'Age': 7}"
3type(variable) 返回输入的变量类型,如果变量是字典就返回字典类型。>>> dict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} >>> type(dict) <class 'dict'>

Python字典包含了以下内置方法:

序号函数及描述
1radiansdict.clear() 删除字典内所有元素
2radiansdict.copy() 返回一个字典的浅复制
3radiansdict.fromkeys() 创建一个新字典,以序列seq中元素做字典的键,val为字典所有键对应的初始值
4radiansdict.get(key, default=None) 返回指定键的值,如果键不在字典中返回 default 设置的默认值
5key in dict 如果键在字典dict里返回true,否则返回false
6radiansdict.items() 以列表返回可遍历的(键, 值) 元组数组
7radiansdict.keys() 返回一个迭代器,可以使用 list() 来转换为列表
8radiansdict.setdefault(key, default=None) 和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
9radiansdict.update(dict2) 把字典dict2的键/值对更新到dict里
10radiansdict.values() 返回一个迭代器,可以使用 list() 来转换为列表
11pop(key,default) 删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值。
12popitem() 随机返回并删除字典中的最后一对键和值。

实例:

#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()给集合添加元素
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值