赞
踩
了解数据容器是什么。
掌握列表的定义格式。
先打开软件,创建一个名为“06_Python的数据容器”的文件夹,并创建一个名为“01_list列表”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示数据容器之:list列表 语法:[元素,元素,...] """ # 定义一个列表list my_list = ["itheima", "itcast", "python"] print(my_list) print(type(my_list)) my_list = ["itheima", 666, True] print(my_list) print(type(my_list)) # 定义一个嵌套的列表 my_list=[[1,2,3],[4,5,6]] print(my_list) print(type(my_list))
掌握使用列表的下标索引从列表中取出元素。
如列表[1][1]就是取出列表中第2个元素(此时的元素也是一个列表)中的第2个元素。
进行代码的演示(为了便于管理文件,先将本节之前的代码文件改成“01_1_ list列表的定义”):
创建一个名为“01_2_列表的下标索引”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示数据容器之:list列表 -下标索引 """ # 通过下标索引取出对应位置的数据 my_list = ["Tom", "Lily", "Rose"] # 列表[下标索引],从前向后从0开始,每次+1, 从后向前从-1开始,每次-1 print(my_list[0]) print(my_list[1]) print(my_list[2]) # 错误示范:通过下标索引取数据,一定不要超出范围 # print(my_list[3]) # 通过下标素引取出数据(倒序取出) print(my_list[-1]) print(my_list[-2]) print(my_list[-3]) # 取出嵌套列表的元素 my_list = [[1, 2, 3], [4, 5, 6]] print(my_list[1][1])
掌握列表的常用操作(方法)和特点。
通过index方法,我们可以接收一个传入的参数,这个参数就是要查找的元素。把元素传进去就会得到一个返回值,这个返回值就会告诉你这个元素在列表中的下标是多少。
注:pop会把取出的元素作为返回值,进行输出。
先打开软件,创建一个名为“01_3_ list列表的常用操作”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。可以体会列表list的查询功能方法index的语法。
"""
演示数据容器之:list列表的常用操作
"""
mylist = ["itcast","itheima","python"]
# 1.1查找某元素在列表内的下标素引
index = mylist.index("itheima")
print(f"itheima在列表中的下标索引值是:{index}")
如果被查找的元素不存在,会 ** !!报错!! ** ,如下重新编写代码并运行,可发现报错提示:在列表中没有找到”Hello”。
"""
演示数据容器之:list列表的常用操作
"""
mylist = ["itcast","itheima","python"]
# 1.1查找某元素在列表内的下标素引
index = mylist.index("itheima")
print(f"itheima在列表中的下标索引值是:{index}")
# 1.2如果被查找的元素不存在,会报错
index = mylist.index("hello")
print(f"hello在列表中的下标索引值是:{index}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会列表的修改功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast","itheima","python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # 2.修改特定下标索引的值 mylist[0] = "传智教育" print(f"列表被修改元素值后,结果是:{mylist}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会列表的插入功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast","itheima","python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # 3.在指定下标位置插入新元素 mylist.insert(1, "best") print(f"列表插入元素后,结果是:{mylist}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会列表追加一个元素的功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast","itheima","python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # 4.在列表的尾部追加'''单个'''新元素 mylist.append("黑马程序员") print(f"列表在追加了元素后,结果是:{mylist}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会列表追加一批元素的功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast", "itheima", "python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # # 4.在列表的尾部追加'''单个'''新元素 # mylist.append("黑马程序员") # print(f"列表在追加了元素后,结果是:{mylist}") # 5.在列表的尾部追加'''一批'''新元素 mylist2 = [1, 2, 3] mylist.extend(mylist2) print(f"列表在追加了一个新的列表后,结果是:{mylist}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会列表的删除元素功能。并可以验证pop会把取出的元素作为返回值,进行输出。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast", "itheima", "python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # # 4.在列表的尾部追加'''单个'''新元素 # mylist.append("黑马程序员") # print(f"列表在追加了元素后,结果是:{mylist}") # # 5.在列表的尾部追加'''一批'''新元素 # mylist2 = [1, 2, 3] # mylist.extend(mylist2) # print(f"列表在追加了一个新的列表后,结果是:{mylist}") # 6.删除指定下标索引的元素(2种方式) # 6.1 方式1:de1列表[下标] del mylist[2] print(f"列表删除元素后结果是:{mylist}") # 6.2 方式2:列表.pop(下标) mylist = ["itcast", "itheima", "python"] element = mylist.pop(2) print(f"通过pop方法取出元素后列表内容:{mylist},取出的元素是:{element}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会删除某元素在列表中的第一个匹配项的功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast", "itheima", "python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # # 4.在列表的尾部追加'''单个'''新元素 # mylist.append("黑马程序员") # print(f"列表在追加了元素后,结果是:{mylist}") # # 5.在列表的尾部追加'''一批'''新元素 # mylist2 = [1, 2, 3] # mylist.extend(mylist2) # print(f"列表在追加了一个新的列表后,结果是:{mylist}") # # 6.删除指定下标索引的元素(2种方式) # # 6.1 方式1:de1列表[下标] # del mylist[2] # print(f"列表删除元素后结果是:{mylist}") # # 6.2 方式2:列表.pop(下标) # mylist = ["itcast", "itheima", "python"] # element = mylist.pop(2) # print(f"通过pop方法取出元素后列表内容:{mylist},取出的元素是:{element}") # 7 删除某元素在列表中的第一个匹配项 mylist = ["itcast","itheima","itcast","itheima","python"] mylist.remove("itheima") print(f"通过remove方法移除元素后,列表的结果是:{mylist}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会清空列表的功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast", "itheima", "python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # # 4.在列表的尾部追加'''单个'''新元素 # mylist.append("黑马程序员") # print(f"列表在追加了元素后,结果是:{mylist}") # # 5.在列表的尾部追加'''一批'''新元素 # mylist2 = [1, 2, 3] # mylist.extend(mylist2) # print(f"列表在追加了一个新的列表后,结果是:{mylist}") # # 6.删除指定下标索引的元素(2种方式) # # 6.1 方式1:de1列表[下标] # del mylist[2] # print(f"列表删除元素后结果是:{mylist}") # # 6.2 方式2:列表.pop(下标) # mylist = ["itcast", "itheima", "python"] # element = mylist.pop(2) # print(f"通过pop方法取出元素后列表内容:{mylist},取出的元素是:{element}") # # 7 删除某元素在列表中的第一个匹配项 # mylist = ["itcast","itheima","itcast","itheima","python"] # mylist.remove("itheima") # print(f"通过remove方法移除元素后,列表的结果是:{mylist}") # 8.清空列表 mylist.clear() print(f"列表被清空了,结果是:{mylist}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会列表中指定元素的计数功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast", "itheima", "python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # # 4.在列表的尾部追加'''单个'''新元素 # mylist.append("黑马程序员") # print(f"列表在追加了元素后,结果是:{mylist}") # # 5.在列表的尾部追加'''一批'''新元素 # mylist2 = [1, 2, 3] # mylist.extend(mylist2) # print(f"列表在追加了一个新的列表后,结果是:{mylist}") # # 6.删除指定下标索引的元素(2种方式) # # 6.1 方式1:de1列表[下标] # del mylist[2] # print(f"列表删除元素后结果是:{mylist}") # # 6.2 方式2:列表.pop(下标) # mylist = ["itcast", "itheima", "python"] # element = mylist.pop(2) # print(f"通过pop方法取出元素后列表内容:{mylist},取出的元素是:{element}") # # 7 删除某元素在列表中的第一个匹配项 # mylist = ["itcast","itheima","itcast","itheima","python"] # mylist.remove("itheima") # print(f"通过remove方法移除元素后,列表的结果是:{mylist}") # # 8.清空列表 # mylist.clear() # print(f"列表被清空了,结果是:{mylist}") # 9.统计列表内某元素的数量 mylist = ["itcast", "itheima", "itcast", "itheima", "python"] count = mylist.count("itheima") print(f"列表中itheimaf的数量是:{count}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),体会统计列表中全部元素的功能。
""" 演示数据容器之:list列表的常用操作 """ mylist = ["itcast", "itheima", "python"] # # 1.1查找某元素在列表内的下标素引 # index = mylist.index("itheima") # print(f"itheima在列表中的下标索引值是:{index}") # # # 1.2如果被查找的元素不存在,会报错 # # index = mylist.index("hello") # # print(f"hello在列表中的下标索引值是:{index}") # # 2.修改特定下标索引的值 # mylist[0] = "传智教育" # print(f"列表被修改元素值后,结果是:{mylist}") # # 3.在指定下标位置插入新元素 # mylist.insert(1, "best") # print(f"列表插入元素后,结果是:{mylist}") # # 4.在列表的尾部追加'''单个'''新元素 # mylist.append("黑马程序员") # print(f"列表在追加了元素后,结果是:{mylist}") # # 5.在列表的尾部追加'''一批'''新元素 # mylist2 = [1, 2, 3] # mylist.extend(mylist2) # print(f"列表在追加了一个新的列表后,结果是:{mylist}") # # 6.删除指定下标索引的元素(2种方式) # # 6.1 方式1:de1列表[下标] # del mylist[2] # print(f"列表删除元素后结果是:{mylist}") # # 6.2 方式2:列表.pop(下标) # mylist = ["itcast", "itheima", "python"] # element = mylist.pop(2) # print(f"通过pop方法取出元素后列表内容:{mylist},取出的元素是:{element}") # # 7 删除某元素在列表中的第一个匹配项 # mylist = ["itcast","itheima","itcast","itheima","python"] # mylist.remove("itheima") # print(f"通过remove方法移除元素后,列表的结果是:{mylist}") # # 8.清空列表 # mylist.clear() # print(f"列表被清空了,结果是:{mylist}") # # 9.统计列表内某元素的数量 # mylist = ["itcast", "itheima", "itcast", "itheima", "python"] # count = mylist.count("itheima") # print(f"列表中itheimaf的数量是:{count}") # 10.统计列表中全部的元素数量 mylist = ["itcast", "itheima", "itcast", "itheima", "python"] count = len(mylist) print(f"列表的元素数量总共有:{count}个")
创建一个名为“01_4_ list列表常用操作课后练习”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示list常用操作的课后练习 """ # 1.定义这个列表,并用变量接收它,内容是:[21,25,21,23,22,20] mylist = [21, 25, 21, 23, 22, 20] # 2.追加一个数字31,到列表的尾部 mylist.append(31) # 3.追加一个新列表[29,33,30],到列表的尾部 mylist.extend([29, 33, 30]) # 4.取出第一个元素(应是:21) num1 = mylist[0] print(f"从列表中取出来第一个元素,应该是21,实际上是:{num1}") # 5.取出最后一个元素(应是:30) num2 = mylist[-1] print(f"从列表中取出来最后一个元素,应该是30,实际上是:{num2}") # 6.查找元素31,在列表中的下标位置 index = mylist.index(31) print(f"元素31在列表的下标位置是:{index}") print(f"最后列表的内容是:{mylist}")
掌握使用while循环,遍历列表的元素;掌握使用for循环,遍历列表的元素。
创建一个名为“02_Iist列表的循环”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。从中学会while循环对列表的遍历。
""" 演示对list列表的循坏,使用while和for循环2种方式 """ # 1.使用while循环对list列表进行遍历 def list_while_func(): """ 使用while循环遍历列表的演示函数 :return:None """ my_list = ["传智教育", "黑马程序员", "Python"] # 循坏控制变量通过下标索引来控制,默认0 # 每一次循环将下标索引变量+1 # 循环条件:下标索引变量<列表的元素数量 # 定义一个变量用来标记列表的下标 index = 0 # 初始值为0 while index < len(my_list): # 通过index变量取出对应下标的元素 element = my_list[index] print(f"列表的元素:{element}") # 至关重要将循环变量(index)每一次循坏都+1 index += 1 list_while_func()
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释),从中学会for循环对列表的遍历。
""" 演示对list列表的循坏,使用while和for循环2种方式 """ # # 1.使用while循环对list列表进行遍历 # def list_while_func(): # """ # 使用while循环遍历列表的演示函数 # :return:None # """ # my_list = ["传智教育", "黑马程序员", "Python"] # # # 循坏控制变量通过下标索引来控制,默认0 # # 每一次循环将下标索引变量+1 # # 循环条件:下标索引变量<列表的元素数量 # # 定义一个变量用来标记列表的下标 # index = 0 # 初始值为0 # while index < len(my_list): # # 通过index变量取出对应下标的元素 # element = my_list[index] # print(f"列表的元素:{element}") # # # 至关重要将循环变量(index)每一次循坏都+1 # index += 1 # # # list_while_func() # 2.使用for循环对list列表进行遍历 def list_for_func(): """ 使用for循环遍历列表的演示函数 :return:None """ my_list = [1, 2, 3, 4, 5] # for 临时变量 in 数据容器: for element in my_list: print(f"列表的元素有:{element}") list_for_func()
掌握元组的定义格式;掌握元组的特点;掌握元组的常见操作。
元组可理解成只读的list。
创建一个名为“03_ tuple元组”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。在编程中要学会元组的定义方法,需要注意的是,其中仅含一个元素的元组的定义语法,要在后面加逗号。
""" 演示tuple元组的定义和操作 """ # 定义元组 t1 = (1, "Hello", True) t2 = () t3 = tuple() print(f"t1的类型是:{type(t1)},内容是:{t1}") print(f"t2的类型是:{type(t2)},内容是:{t2}") print(f"t3的类型是:{type(t3)},内容是:{t3}") # 定义单个元素的元素 t4 = ("hello") print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") t4 = ("hello",) print(f"t4的类型是:{type(t4)},t4的内容是:{t4}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释)。代码如下,可参考注释进行理解。在编程中要学会元组的嵌套以及在嵌套情况下如何取内层里的元素。
""" 演示tuple元组的定义和操作 """ # # 定义元组 # t1 = (1, "Hello", True) # t2 = () # t3 = tuple() # print(f"t1的类型是:{type(t1)},内容是:{t1}") # print(f"t2的类型是:{type(t2)},内容是:{t2}") # print(f"t3的类型是:{type(t3)},内容是:{t3}") # # # 定义单个元素的元素 # t4 = ("hello") # print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") # t4 = ("hello",) # print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") # 元组的嵌套 t5 = ((1, 2, 3), (4, 5, 6)) print(f"t5的类型是:{type(t5)},内容是:{t5}") # 下标索引去取出内容 num = t5[1][2] print(f"从嵌套元组中取出的数据是:{num}")
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释)。代码如下,可参考注释进行理解。在编程中要学会元组的相关操作以及遍历。
""" 演示tuple元组的定义和操作 """ # # 定义元组 # t1 = (1, "Hello", True) # t2 = () # t3 = tuple() # print(f"t1的类型是:{type(t1)},内容是:{t1}") # print(f"t2的类型是:{type(t2)},内容是:{t2}") # print(f"t3的类型是:{type(t3)},内容是:{t3}") # # # 定义单个元素的元素 # t4 = ("hello") # print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") # t4 = ("hello",) # print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") # # 元组的嵌套 # t5 = ((1, 2, 3), (4, 5, 6)) # print(f"t5的类型是:{type(t5)},内容是:{t5}") # # # 下标索引去取出内容 # num = t5[1][2] # print(f"从嵌套元组中取出的数据是:{num}") # 元组的操作:index查找方法 t6 = ("传智教育", "黑马程序员", "Python") index = t6.index("黑马程序员") print(f"在元组t6中查找 黑马程序员 的下标是:{index}") # 元组的操作:count统计方法 t7 = ("传智教育", "黑马程序员", "黑马程序员", "黑马程序员", "Python") num = t7.count("黑马程序员") print(f"在元组t7中统计黑马程序员的数量有:{num}个") # 元组的操作:len函数统计元组元素数量 t8 = ("传智教育", "黑马程序员", "黑马程序员", "黑马程序员", "Python") num = len(t8) print(f"t8元组中的元素有:{num}个") # 元组的遍历:while index = 0 while index < len(t8): print(f"元组的元素有:{t8[index]}") # 至关重要 index += 1 # 元组的遍历:for for element in t8: print(f"元组t8的元素有:{element}")
如果尝试修改元组的数据,会报错,这是一个错误示例。
如下重新编写代码并运行(使用快捷键Ctr+/可快速注释)。代码如下,可参考注释进行理解。在编程中可发现:可以修改元组内的列表list的内容。
""" 演示tuple元组的定义和操作 """ # # 定义元组 # t1 = (1, "Hello", True) # t2 = () # t3 = tuple() # print(f"t1的类型是:{type(t1)},内容是:{t1}") # print(f"t2的类型是:{type(t2)},内容是:{t2}") # print(f"t3的类型是:{type(t3)},内容是:{t3}") # # # 定义单个元素的元素 # t4 = ("hello") # print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") # t4 = ("hello",) # print(f"t4的类型是:{type(t4)},t4的内容是:{t4}") # # 元组的嵌套 # t5 = ((1, 2, 3), (4, 5, 6)) # print(f"t5的类型是:{type(t5)},内容是:{t5}") # # # 下标索引去取出内容 # num = t5[1][2] # print(f"从嵌套元组中取出的数据是:{num}") # # 元组的操作:index查找方法 # t6 = ("传智教育", "黑马程序员", "Python") # index = t6.index("黑马程序员") # print(f"在元组t6中查找 黑马程序员 的下标是:{index}") # # # 元组的操作:count统计方法 # t7 = ("传智教育", "黑马程序员", "黑马程序员", "黑马程序员", "Python") # num = t7.count("黑马程序员") # print(f"在元组t7中统计黑马程序员的数量有:{num}个") # # # 元组的操作:len函数统计元组元素数量 # t8 = ("传智教育", "黑马程序员", "黑马程序员", "黑马程序员", "Python") # num = len(t8) # print(f"t8元组中的元素有:{num}个") # # # 元组的遍历:while # index = 0 # while index < len(t8): # print(f"元组的元素有:{t8[index]}") # # 至关重要 # index += 1 # # # 元组的遍历:for # for element in t8: # print(f"元组t8的元素有:{element}") # # 修改元组内容 由于元组不可修改,显然这是一个错误示例 # t8[0] = "itcast" # 定义一个元组 t9 = (1, 2, ["itheima", "itcast"]) print(f"t9的内容是:{t9}") t9[2][0] = "黑马程序员" t9[2][1] = "传智教育" print(f"t9的内容是:{t9}")
掌握字符串的常见操作。
另外,count可用于统计字符串中某字符串的出现次数, len可用于统计字符串的长度, 具体使用方法与列表一样,本节也进行了代码的演示。
先打开软件,创建一个名为“04_字符串”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示以数据容器的角色,学习字符串的相关操作 """ my_str = "itheima and itcast" # 通过下标索引取值 value = my_str[2] value2 = my_str[-16] print(f"从字符串{my_str}取下标为2的元素的值是:{value},取下标为-16的元素的值是:{value2}") # 字符串不可修改,下面的操作 !!不可!! 完成 # my_str[2] = "H" # index方法 valve = my_str.index("and") print(f"在字符串{my_str}中查找and,其起始下标是:{valve}") # replace方法 new_my_str = my_str.replace("it", "程序") print(f"将字符串{my_str},进行替换后得到:{new_my_str}") # split方法 my_str = "hello python itheima itcast" my_str_list = my_str.split(" ") print(f"将字符串{my_str}进行split切分后得到:{my_str_list},类型是:{type(my_str_list)}") # strip方法 my_str = " itheima and itcast " new_my_str = my_str.strip() # 不传入参数,去除首尾空格 print(f"字符串{my_str}被strip后,结果:{new_my_str}") my_str = "12itheima and itcast21" new_my_str = my_str.strip("12") # 去除首尾的数字1和2 print(f"字符串{my_str}被strip('12')后,结果:{new_my_str}") # 统计字符串中某字符串的出现次数, count my_str = "itheima and itcast" count = my_str.count("it") print(f"字符串{my_str}中it出现的次数是:{count}") # 统计字符串的长度, len num = len(my_str) print(f"字符串{my_str}的长度是:{num}")
进行代码的演示(为了便于管理文件,先将本节之前的代码文件改成“04_1_字符串”):
创建一个名为“04_2_字符串课后练习”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 字符串课后练习演示 "itheima itcast boxuegu" """ my_str = "itheima itcast boxuegu" # 统计字符串内有多少个"1t"字符 num = my_str.count("it") print(f"字符串{my_str}中有{num}个it字符") # 将字符串内的空格,全部替换为字符:”|” new_my_str = my_str.replace(" ", "|") print(f"字符串{my_str}被替换空格后,结果是:{new_my_str}") # 并按照”|”进行字符串分割,得到列表 my_str_list = new_my_str.split("|") print(f"字符串{new_my_str}按照|分割后结果是:{my_str_list}")
了解什么是序列;掌握序列的切片操作。
注意,此操作不会影响序列本身,而是会得到一个新的序列(列表、元组或字符串),这是因为元组和字符串是不支持修改的。
先打开软件,创建一个名为“05_序列和切片”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示对序列进行切片操作 """ # 对list进行切片,从1开始,4结束,步长1 my_list = [0, 1, 2, 3, 4, 5, 6] result1 = my_list[1:4] # 步长默认是1,所以可以省略不写 print(f"结果1:{result1}") # 对tuple进行切片,从头开始,到最后结束,步长1 my_tuple = (0, 1, 2, 3, 4, 5, 6) result2 = my_tuple[:] # 起始和结束不写表示从头到尾,步长为1可以省略 print(f"结果2:{result2}") # 对str下进行切片,从头开始,到最后结束,步长2 my_str = "01234567" result3 = my_str[::2] print(f"结果3:{result3}") # 对str进行切片,从头开始,到最后结束,步长-1 my_str = "01234567" result4 = my_str[::-1] # 等同于将序列反转了 print(f"结果4:{result4}") # 对列表进行切片,从3开始,到1结束,步长-1 my_1ist = [0, 1, 2, 3, 4, 5, 6] result5 = my_list[3:1:-1] print(f"结果5:{result5}") # 对元组进行切片,从头开始,到尾结束,步长-2 my_tuple = (0, 1, 2, 3, 4, 5, 6) result6 = my_tuple[::-2] print(f"结果6:{result6}")
进行代码的演示(为了便于管理文件,先将本节之前的代码文件改成“05_1_序列和切片”):
创建一个名为“05_2_序列切片课后练习”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示序列的切片的课后练习 "万过薪月,员序程马黑来,nohtyP学" """ my_str = "万过薪月,员序程马黑来,nohtyP学" # 倒序字符串,切片取出 result1 = my_str[::-1][9:14] print(f"方式1结果:{result1}") # 切片取出,然后倒序 result2 = my_str[5:10][::-1] print(f"方式2结果:{result2}") # split分隔",",replace替换"来"为空,倒序字符串 result3 = my_str.split(",")[1].replace("来", "")[::-1] print(f"方式3结果:{result3}")
掌握集合的定义格式;掌握集合的特点;掌握集合的常见操作。
注:由于集合是无序的,所以它不是序列。
注:其实也能支持while循环,可参考代码演示或者b站上的一条弹幕。
先打开软件,创建一个名为“06_集合”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示数据容器集合的使用 """ # 定义集合 my_set = {"传智教育", "黑马程序员", "itheima", "传智教育", "黑马程序员", "itheima", "传智教育", "黑马程序员", "itheima"} my_set_empty = set() # 定义空集合 print(f"my_set的内容是:{my_set},类型是:{type(my_set)}") print(f"my_set_empty的内容是:{my_set_empty},类型是:{type(my_set_empty)}") # 添加新元素 my_set.add("Python") my_set.add("传智教育") print(f"my_set添加元素后结果是:{my_set}") # 移除元素 my_set.remove("黑马程序员") print(f"my_set移除黑马程序员后,结果是:{my_set}") # 随机取出一个元素 my_set = {"传智教育", "黑马程序员", "itheima"} element = my_set.pop() print(f"集合被取出元素是:{element},取出元素后:{my_set}") # 清空集合,clear my_set.clear() print(f"集合被清空啦,结果是:{my_set}") # 取2个集合的差集 set1 = {1, 2, 3} set2 = {1, 5, 6} set3 = set1.difference(set2) print(f"取出差集后的结果是:{set3}") print(f"取差集后,原有set1的内容:{set1}") print(f"取差集后,原有set2的内容:{set2}") # 消除2个集合的差集 set1 = {1, 2, 3} set2 = {1, 5, 6} set1.difference_update(set2) print(f"消除差集后,set1的内容:{set1}") print(f"消除差集后,set2的内容:{set2}") # 2个集合合并为1个 set1 = {1, 2, 3} set2 = {1, 5, 6} set3 = set1.union(set2) print(f"2集合合并结果:{set3}") print(f"合并后集合1:{set1}") print(f"合并后集合2:{set2}") # 统计集合元素数量len() set1 = {1, 2, 3, 4, 5} num = len(set1) print(f"集合内的元素数量有:{num}个") # 集合的遍历 # 集合不支持下标索引,while循环不能像常规的while循环一样进行遍历 while循环需要改变循环条件 # 可以用刷0r循环 set1 = {1, 2, 3, 4, 5} for element in set1: print(f"集合的元素有:{element}") my_set = {"传智教育", "黑马程序员", "itheima"} # b站一大佬给的弹幕提示 while my_set != set(): a = my_set.pop() print(a)
进行代码的演示(为了便于管理文件,先将本节之前的代码文件改成“06_1_集合”):
创建一个名为“06_2_集合课后练习-信息去重”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示集合的课后练习题 my_list = ['黑马程序员', '传智播客', '黑马程序员', '传智播客', 'itheima', 'itcast', 'itheima', 'itcast', 'best'] """ my_list = ['黑马程序员', '传智播客', '黑马程序员', '传智播客', 'itheima', 'itcast', 'itheima', 'itcast', 'best'] # 定义一个空集合 my_set = set() # 通过f0下循环遍历列表 for element in my_list: # 在for下循环中将列表的元素添加至集合 my_set.add(element) # 最终得到元素去重后的集合对象,并打印输出 print(f"列表的内容是:{my_list}") print(f"通过for循环后,得到的集合对象是:{my_set}")
掌握字典的定义格式。
注:Python中字典的Key是不可以重复的,如果真定义相同的Key,后面的会把前面的覆盖。
注:格式可参考演示。
先打开软件,创建一个名为“07_1_字典的定义”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示数据容器字典的定义 """ # 定义字典 my_dict1 = {"王力鸿": 99, "周杰轮": 88, "林俊节": 77} # 定义空字典 my_dict2 = {} my_dict3 = dict() print(f"字典1的内容是:{my_dict1},类型:{type(my_dict1)}") print(f"字典2的内容是:{my_dict2},类型:{type(my_dict2)}") print(f"字典3的内容是:{my_dict3},类型:{type(my_dict3)}") # # 定义重复Key的字典 注:Python中字典的Key是不可以重复的,如果真定义相同的Key,后面的会把前面的覆盖。 # my_dict1 = {"王力鸿": 99, "王力鸿": 88, "林俊节": 77} # print(f"重复key的字典的内容是:{my_dict1}") # 从字典中基于Key获取value my_dict1 = {"王力鸿": 99, "周杰轮": 88, "林俊节": 77} score = my_dict1["王力鸿"] print(f"王力鸿的考试分数是:{score}") score = my_dict1["周杰轮"] print(f"周杰轮的考试分数是:{score}") # 定义嵌套字典 stu_score_dict = { "王力鸿": { "语文": 77, "数学": 66, "英语": 33 }, "周杰轮": { "语文": 88, "数学": 86, "英语": 55 }, "林俊节": { "语文": 99, "数学": 96, "英语": 66 } } print(f"学生的考试信息是:{stu_score_dict}") # 从嵌套字典中获取数据 # 看一下周杰轮的语文信息 score = stu_score_dict["周杰轮"]["语文"] print(f"周杰轮的语文分数是:{score}") score = stu_score_dict["林俊节"]["英语"] print(f"林俊节的英语分数是:{score}")
掌握字典的常用操作;掌握字典的特点。
先打开软件,创建一个名为“07_2_字典的常用操作”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示字典的常用操作 """ my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77} # 新增元素 my_dict["张信哲"] = 66 print(f"字典经过新增元素后,结果:{my_dict}") # 更新元素 my_dict["周杰轮"] = 33 print(f"字典经过更新后,结果:{my_dict}") # 删除元素 score = my_dict.pop("周杰轮") print(f"字典中被移除了一个元素,结果:{my_dict},周杰轮的考试分数是:{score}") # 清空元素,clear my_dict.clear() print(f"字典被清空了,内容是:{my_dict}") # 获取全部的key my_dict = {"周杰轮": 99, "林俊节": 88, "张学油": 77} keys = my_dict.keys() print(f"字典的全部keys是:{keys}") # 遍历字典 # 方式1:通过获取到全部的key来完成遍历 for key in keys: print(f"字典的key是:{key}") print(f"字典的valve是:{my_dict[key]}") # 方式2:直接对字典进付or循环,每一次循坏都是直接得到key for key in my_dict: print(f"2字典的key是:{key}") print(f"2字典的valve是:{my_dict[key]}") # 统计字典内的元素数量,len()函数 num = len(my_dict) print(f"字典中的元素数量有:{num}个")
创建一个名为“07_3_字典课后练习”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示字典的课后练习:升职加薪,对所有级别为1级的员工,级别上升1级,薪水增加加080元 """ # 组织字典记录数据 info_dict = { "王力鸿": { "部门": "科技部", "工资": 3000, "级别": 1 }, "周杰轮": { "部门": "市场部", "工资": 5000, "级别": 2 }, "林俊节": { "部门": "市场部", "工资": 3000, "级别": 1 }, "张学油": { "部门": "科技部", "工资": 4000, "级别": 1 }, "刘德滑": { "部门": "市场部", "工资": 6000, "级别": 2 } } print(f"员工在升值加薪之前的结果:{info_dict}") # for循环遍历字典 for name in info_dict: # if条件判惭符合条件员工 if info_dict[name]["级别"] == 1: # 升职加薪操作 # 获取到员工的信息字典 employee_info_dict = info_dict[name] # 修改员工的信息 employee_info_dict["级别"] = 2 # 级别+1 employee_info_dict["工资"] += 1000 # 工资+1000 # 将员工的信息更新回1nfo_dict info_dict[name] = employee_info_dict # 输出结果 print(f"对员工进行升级加薪后的结果是:{info_dict}")
注:其实集合可以使用while循环进行遍历,详细见那一节的演示。
sorted的第一个参数是被排序的容器,第二个参数是一个有默认值的参数,叫做reverse,它是反转的意思,默认为False, 如果想让容器的排序结果进行反转,可以传递一个True。这样,就能控制容器进行从小到大的排序,或者反过来从大到小的排序。另外需要注意的是,排序的结果对象为列表。
先打开软件,创建一个名为“08_数据容器的通用功能”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
""" 演示数据容器的通用功能 """ my_list = [1, 2, 3, 4, 5] my_tuple = (1, 2, 3, 4, 5) my_str = "abcdefg" my_set = {1, 2, 3, 4, 5} my_dict = {"key1": 1, "key2": 2, "key3": 3, "key4": 4, "key5": 5} # Len元素个数 print(f"列表元素个数有:{len(my_list)}") print(f"元组元素个数有:{len(my_tuple)}") print(f"字符串元素个数有:{len(my_str)}") print(f"集合元素个数有:{len(my_set)}") print(f"字典元素个数有:{len(my_dict)}") # max最大元素 print(f"列表中最大的元素是:{max(my_list)}") print(f"元组中最大的元素是:{max(my_tuple)}") print(f"字符串中最大的元素是:{max(my_str)}") print(f"集合中最大的元素是:{max(my_set)}") # min最小元素 print(f"列表中最小的元素是:{min(my_list)}") print(f"元组中最小的元素是:{min(my_tuple)}") print(f"字符串中最小的元素是:{min(my_str)}") print(f"集合中最小的元素是:{min(my_set)}") # 类型转换:容器转列表 print(f"列表转列表的结果是:{list(my_list)}") print(f"元组转列表的结果是:{list(my_tuple)}") print(f"字符串转列表结果是:{list(my_str)}") print(f"集合转列表的结果是:{list(my_set)}") print(f"字典转列表的结果是:{list(my_dict)}") # 类型转换:容器转元组 print(f"列表转元组的结果是:{tuple(my_list)}") print(f"元组转元组的结果是:{tuple(my_tuple)}") print(f"字符串转元组结果是:{tuple(my_str)}") print(f"集合转元组的结果是:{tuple(my_set)}") print(f"字典转元组的结果是:{tuple(my_dict)}") # 类型转换:容器转字符串 print(f"列表转字符串的结果是:{str(my_list)}") # 结果:"[1, 2, 3, 4, 5]" print(f"元组转字符串的结果是:{str(my_tuple)}") # 结果:"(1, 2, 3, 4, 5)" print(f"字符串转字符串结果是:{str(my_str)}") print(f"集合转字符串的结果是:{str(my_set)}") print(f"字典转字符串的结果是:{str(my_dict)}") # 类型转换:容器转集合 print(f"列表转集合的结果是:{set(my_list)}") print(f"元组转集合的结果是:{set(my_tuple)}") print(f"字符串转集合结果是:{set(my_str)}") print(f"集合转集合的结果是:{set(my_set)}") # 无序,且会去掉重合元素 print(f"字典转集合的结果是:{set(my_dict)}") # 进行容器的排序 排序的结果对象为列表 my_1ist = [3, 1, 2, 5, 4] my_tuple = (3, 1, 2, 5, 4) my_str = "bdcefga" my_set = {3, 1, 2, 5, 4} # 正向排序 my_dict = {"key3": 1, "key1": 2, "key2": 3, "key5": 4, "key4": 5} print(f"列表对象的排序结果:{sorted(my_list)}") print(f"元组对象的排序结果:{sorted(my_tuple)}") print(f"字符串对象的排序结果:{sorted(my_str)}") print(f"集合对象的排序结果:{sorted(my_set)}") print(f"字典对象的排序结果:{sorted(my_dict)}") # 反向排序 print(f"列表对象的反向排序结果:{sorted(my_list, reverse = True)}") print(f"元组对象的反向排序结果:{sorted(my_tuple, reverse = True)}") print(f"字符串对象反向的排序结果:{sorted(my_str, reverse = True)}") print(f"集合对象的反向排序结果:{sorted(my_set, reverse = True)}") print(f"字典对象的反向排序结果:{sorted(my_dict, reverse = True)}")
先打开软件,创建一个名为“09_字符串大小比较”的py文件。
编写代码并运行。代码如下,可参考注释进行理解。
"""
演示字符串大小比较
"""
# abc 比较 abd
print(f"abd大于abc,结果:{'abd' > 'abc'}")
# a 比较 ab
print(f"ab大于a,结果:{'ab' > 'a'}")
# a 比较 A
print(f"a大于A,结果:{'a' > 'A'}")
# key1 比铰 key2
print(f"key2>key1,结果:{'key2' > 'key1'}")
好了,本章的笔记到此结束,谢谢大家阅读。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。