py_列表的操作方法
一、列表
列表是python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如:
li = [‘alex’,123,Ture,(1,2,3,’wusir’),[1,2,3,’小明’,],{‘name’:’alex’}]
列表相比于字符串,不仅可以储存不同的数据类型,而且可以储存大量数据,32位python的限制是 536870912 个元素,64位python的限制是 1152921504606846975 个元素。而且列表是有序的,有索引值,可切片,方便取值。
增:
s = ['alex','wusir','taibai'] # append 追加 s.append('henry') # insert 插入 s.insert(1,'henry') # extend 迭代追加 s.extend('henry') s.extend(['oldboy','girl'])
删:
s = ['alex','wusir','taibai',10,11] pop 按照索引删除,会将删除的元素作为返回值(默认删除最后一个) s.pop(1) remove 按照元素删除 s.remove('wusir') clear 清空列表 s.clear() del 按照索引删除 del s[1] 按照切片删除 del s[1:2] 删除整个列表
del s
改:
s = ['alex','wusir','taibai',10,11] 切片改 s[:1] = 'asdf' 切片加步长改 必须一一对应 s[::2] = ['a','b','c']
查:
按照索引 按照切片 加步长查询 for 循环查询 s = ['alex','wusir','taibai',10,11]print(s)
列表的其他操作:
获取列表的长度 len() 计算某个元素出现的次数 conut 通过元素查找索引,找到第一个就返回,找不到就报错 从小到大排序sort(reverse = False) 当reverse = True时从大到小 反转用 reverse 查找某个元素的索引用 index 找到第一个就返回,找不到报错
作业:
1.请⽤代码实现: li = ["alex", "wusir", "taibai"] 利⽤下划线将列表的每⼀个元素拼接成字符串"alex_wusir_taibai"
2.利⽤for循环和range打印出下⾯列表的索引。
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
3.利⽤for循环和range找出100以内所有的偶数并将这些偶数插⼊到⼀个新列表中。
4.利⽤for循环和range 找出50以内能被3整除的数,并将这些数插⼊到⼀个新列表中。
5.利⽤for循环和range从100~1,倒序打印。
6.利⽤for循环和range从100~10,倒序将所有的偶数添加到⼀个新列表中,然后对列 表的元素进⾏筛选,将能被4整除的数留下来。
7.利⽤for循环和range,将1-30的数字⼀次添加到⼀个列表中,并循环这个列表,将 能被3整除的数改成*。
8.查找列表li中的元素,移除每个元素的空格,并找出以"A"或者"a"开头,并以"c"结尾 的所有元素,并添加到⼀个新列表中,后循环打印这个新列表。 li = ["TaiBai ", "alexC", "AbC ", "egon", " riTiAn", "WuSir", " aqc"]
9.开发敏感词语过滤程序,提示⽤户输⼊评论内容,如果⽤户输⼊的内容中包含特殊的 字符: 敏感词列表 li = ["苍⽼师", "东京热", "武藤兰", "波多野结⾐"] 则将⽤户输⼊的内容中的敏感词汇替换成等⻓度的*(苍⽼师就替换***),并添加到⼀ 个列表中;如果⽤户输⼊的内容没有敏感词汇,则直接添加到上述的列表中。
第一题 li = ["alex", "wusir", "taibai"] up = '_'.join(li) print(up) 第二题 li = ["alex", "WuSir", "ritian", "barry", "wenzhou"] for i in range(len(li)): print(i,li[i]) 第三题 lis1 = [] for i in range(2,100,2): # print(i) lis1.append(i) print(lis1) 第四题 lis2 = [] for i in range(50): if i % 3 == 0: lis2.append(i) print(lis2) 第五题 for i in range(100,0,-1): print(i) 第六题 lis3 = [] for i in range(100,11,-1): if i % 2 == 0: lis3.append(i) for v in lis3: if v % 4 != 0: lis3.remove(v) print(lis3) 第七题 lis4 = [] for i in range(1,31): lis4.append(i) for v in lis4: if v % 3 == 0: lis4[v-1] = '*' print(lis4) 第八题 lis = [] li = ["TaiBai ", "alexC", "AbC ", "egon", " riTiAn", "WuSir", " aqc"] for i in li: i = i.strip() if i.startswith('A') and i.endswith('c'): lis.append(i) elif i.startswith('a') and i.endswith('c'): lis.append(i) for v in lis: print(v) 第九题 li = ['苍老师','武藤兰','波多野结衣','东京热'] flag = [] comment = input('请输入') for name in li: if name in comment: comment = comment.replace(name,len(name)*'*') flag.append(comment) print(flag)
重点:
""" 利⽤f or循环和range从100~10,倒序将所有的偶数添加到⼀个新列表中,然后对列 表的元素进⾏筛选,将能被4整除的数留下来。 """ lst = [] for x in range(100,9,-1): if x % 2 == 0: lst.append(x) # 使用del完成 # 从前往后遍历列表,如果删除列表中的元素,会有漏删元素的风险。 # 解决方案:从后往前遍历 index = len(lst) - 1 while index >= 0: if lst[index] % 4 != 0: del lst[index] index -= 1 print(lst)