我是靠谱客的博主 高大果汁,最近开发中收集的这篇文章主要介绍第五章:序列(列表,元组,字典,集合,字典,字符串),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1,""""列表:可以存放不同类型的数据"""
a = [1,2,3,4,5,"上山打老虎"]
for each in a:
    print(each)
print(a[0],a[5])
for i in range(0,6):  #用for循环打印列表
    print(a[i])       #用下标只能一次访问一个元素
length = len(a) #获取列表长度
print(a[length - 1])

2."""列表切片:一次性可以获取多个元素"""
print(a[0:3])
print(a[:3])
print(a[0:6:3])  #start,end,step,用冒号分割,中括号(区别于range()) 
                 #用这种标准写法不用多记其他的。

3print(a[5:0:-1])  #倒序输出,注意不包括a[0]
print(a[0])  #a[0] = 1需单独输出
print(a[::-1]) #或者这样倒叙输出
4"""列表的增删改查"""
"""插:append(),extend(迭代对象),切片,insert(A,B)"""
heros = ["钢铁侠","绿巨人"]
heros.append("黑寡妇")      #append()方法每次只能插一个元素,且只能在列表末尾插
heros.extend(["绿皮书","雷神","灭霸"]) #(1),extend()方法可以多个元素,且也只能在末尾插
                                      #(2),extend()方法的参数必须是一个可迭代的对象,
                                      #["绿皮书","雷神","灭霸"]为列表,是可迭代的对象
                                      #尽量用列表是实现,用元组的话会把字符串分割成单个的字符来插入                          
print(heros)
"""用切片的形式也可以实现插入,但是不如append(),extend()方法好理解"""
s = [1,2,3,4,5]
s[len(s):] = [6]
print(s)
s[len(s):] = [7,8,9] #切片可以实现一次性插入多个
print(s)

"""实现任意位置插入元素:insert()方法,insert(A,B):在A位置插入元素B"""
s = [1,3,4,5]
s.insert(1,2) #在s[1]处插入2
print(s)
s.insert(0,0)
s.insert(len(s),6)
print(s)
""""删:remove(元素),pop(下标),clear(整个列表)"""
heros.remove("灭霸")#remove()只删除第一个灭霸,且若删除的元素不存在则会报错
heros.pop(2) #删除下标为2的元素,若pop()不带参数,默认删除最后一个
print(heros)
heros.clear() #直接清空heros列表
print(heros)
"""改"""
#(1),改
heros = ["蜘蛛侠","绿巨人","美国队长"]
heros[0] = "猪八戒"
heros[1:] = ["孙悟空","王昭君","墨子","兰陵王"] #从下标为1的位置开始改,可以比原来的元素多
print(heros)
#(2),排序
nums = [3,2,4,2,6,8,3,9,1]
nums.reverse()
print(nums)
nums.sort()   #升序排序
print(nums)
nums.reverse() #使序列反转一下,原来是升序现在为降序
print(nums)
nums = [3,2,4,2,6,8,3,9,1]
nums.sort(reverse = True) #也可以实现降序
print(nums)
#(3),统计次数与索引 :count(),index(x,start,end)
print(nums.count(3))  #统计某个元素出现的次数
print(heros.index("王昭君"))  #返回第一个位置的王昭君的索引值(下标)
                              #index()方法也有三个参数:x,start,end.
                              #表示从start到end位置查找x的索引
#(4),复制:用copy()或者切片(切片无所不能)亦可直接赋值
nums1 = nums.copy()
print(nums1)
nums2 = nums[:] #用切片实现,切整个列表即为复制
print(nums2)
nums3 = nums  #直接赋值
print(nums3)
s = [1,2,3]
t = [4,5,6]
print((s + t),'n',(s * 3)) #列表相加与列表乘3,输出的两个列表规定以空格分隔。

"""创建二维列表(嵌套列表,矩阵)"""
a = [[1,2,3],[4,5,6],[7,8,9]]
a = [[1,2,3],
     [4,5,6],
     [7,8,9]]         #创建二维列表两种写法
for i in a:           #访问每一个列表,i代表每一个列表
    for each in i:    #访问列表的每一个元素,each 代表每一个元素
        print(each)   #访问每一个元素

for i in a:
    for each in i:
        print(each,end = ' ') #end = ' '表示每个元素后面加一个空格
    print()  #用于换行
print(a[1]) #输出第二个列表
print(a[1][2]) #输出第二行第三列的元素
"""is运算符"""
#A is B 当A , B所至指对象内存地址一样时为True,否则为False
a = 'dong'
b = 'dong'
print(a is b)  # 为True,因为字符串是固定不变的,内存一样
a = [1,2,3]
b = [1,2,3]
print(a is b)  #列表可以改变,所以二者内存地址不同,为False
"""所以创建一个初始为0的二维列表的方法如下:这里比较难理解"""
a = [0] * 6  #此时a是[0,0,0,0,0,0]
for i in range(6):
    a[i] = [0] * 6
print(a)          #创建一个6 * 6的列表


6,"""浅拷贝 :只适用于一维,嵌套列表的话内层只能引用而不能拷贝"""
x = [1,2,3]
y = x #y引用 x,x变y也变
x[1] = 1
y = x.copy() #用copy(),则不同于引用,x,y相互独立。(列表的copy方法)


7,"""深拷贝"""
#列表的copy()方法与copy模块的copy方法不同
import copy
x = [[1,2,3],[4,5,6],[7,8,9]]
y = copy.copy(x) #利用copy模块的copy函数进行深拷贝
x[1][1] = 1
print(x,y)  #x,y都会改变,也是浅拷贝
x = [[1,2,3],[4,5,6],[7,8,9]]
y = copy.deepcopy(x) #深拷贝
x [1][1] = 1
print(x,y)  #当x改变时,y不动


8,"""列表推导式:列表推导式的结果一定是一个列表"""  #注意使用列表推导式虽然简洁且执行快,但维护较难
                                                #同事不易看懂,自己把握使用的度。
#格式:[表达式 + for循环]
"""用for循环实现列表元素乘2"""
x = [1,2,3,4,5]
for i in range(len(x)): #注意与 for i in x写法的区别,不能按下标访问
    x[i] *= 2
print(x)
x = [1,2,3,4,5]
"""以下写法不对"""
for i in x: #注意与 for i in x写法的区别,不能按下标访问
    i *= 2
    print(i) #i = 2,4,6,8,10
print(x)     #x还是[1,2,3,4,5] i * 2对x列表没有影响
"""用列表推导式实现"""
x = [1,2,3,4,5]
x = [i * 2 for i in x]     #比用for循环执行效率高
print(x)
"""列表推到式也可以对字符串操作"""
y = [i * 2 for i in "dongjian"]
print(y)  # ['dd', 'oo', 'nn', 'gg', 'jj', 'ii', 'aa', 'nn']
code = [ord(i) for i in "dongjian"] #用内置函数ord()输出unicode编码
print(code)
"""用列表推导式取出矩阵的某一列"""
a = [[1,2,3],
     [4,5,6],
     [7,8,9]]
column = [row[1] for row in a] #以此取每一行的第二个元素,即取出第二列元素
print(column)
diag = [a[i][i] for i in range(len(a))] # 取出对角线元素
print(diag)
"""for循环创建二维列表"""
a = [0] * 3
for i in range(3):
    a[i]  = [0] * 3
"""用列表推导式创建二维列表"""
a = [[0] * 3 for i in range(3)]
print(a)
"""用if语句用以筛选:执行顺序,先for循环,再if,最后执行表达式i"""
a = [i for i in range(10) if i % 2 == 0]
print(a)
"""找出以F开头的字母:列表表达式 + if条件判断"""
#方法1:
words = ["Frank","Frequence","flat","abandon","Manage","diligent","Flu"]
a = [word for word in words if word[0] == 'F']
print(a)
#方法2:
a = []
for word in words:
    if word[0] == 'F':
        a.append(word)
print(a)


9,"""用列表推导式的嵌套实现降维"""
a = [[1,2,3],[4,5,6],[7,8,9]]
flatter = [column for row in a for column in row]
                            #对比下面的for循环可以看出,第一个是外层循环,第二个是内层循环
print(flatter)
"""用普通的for循环实现降维"""
flatter = []
for row in a:
    for column in row:
        flatter.append(column)
print(flatter)
a = [x + y for x in "fishc" for y in "FishC"]
print(a)
_ = []
"""等价于"""
for x in "fishc":
    for y in "FishC":
        _.append(x + y)
print(_)
"""添加if判断语句"""
a = [[x,y] for x in range(10) if x % 2 == 0 for y in range(10) if y % 3 == 0]
                                                      #将x,y拼接成一个列表[x,y]
print(a)
"""等价于"""
a = []
for x in range(10):
    if x % 2 == 0:
        for y in range(10):
            if y % 3 == 0:
                a.append([x,y])
print(a)

最后

以上就是高大果汁为你收集整理的第五章:序列(列表,元组,字典,集合,字典,字符串)的全部内容,希望文章能够帮你解决第五章:序列(列表,元组,字典,集合,字典,字符串)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部