多平台统一管理软件接口,如何实现多平台统一管理软件接口
406
2022-08-28
Python列表常用方法总结
一、创建列表
① 只要把逗号分隔的不同的数据项使用方括号[ ]括起来即可;
下标(角标,索引)从0开始;最后一个元素的下标可以是-1;
list = ['1',‘2,‘3’]list = [] list = list()list2 = list()print(list2, type(list2)) # []
② list() 方法将元组转换为列表;但是元组变成列表后的对象内存地址没变。
a_tuple = ('123', 'abc', 123)print(a_tuple, id(a_tuple)) # ('123', 'abc', 123) 2374451842688a_list = list(a_tuple)print(a_list, id(a_list)) # ['123', 'abc', 123] 2374451917888
二、列表添加新元素
① list.append()默认在列表的末尾增加一个元素。
② list.insert(4,'a')在指定位置添加元素;【注意】①如果指定的下标对应的元素不存在,那么就是默认在列表的末尾添加新的元素【在下标为4的元素位置添加a元素】;②如果传入的指定下标不存在即超出了该列表的索引值,同样也会插入成功而不报错;③insert之后的列表对象不变,即不会产生一个新的列表对象
list1 = ['1', '2', '3']print(id(list1)) # 3019052845760list1.insert(1, 'a')print(list1, id(list1)) # ['1', 'a', '2', '3'] 3019052845760list1.insert(100, 'b')print(list1, id(list1)) # ['1', 'a', '2', '3', 'b'] 3019052845760list1.insert(-1, 'c')print(list1, id(list1)) # ['1', 'a', '2', '3', 'c', 'b'] 3019052845760list1.insert(-2, 'd')print(list1, id(list1)) # ['1', 'a', '2', '3', 'd', 'c', 'b'] 3019052845760list1.insert(-100, 'fg')print(list1, id(list1)) # ['fg', '1', 'a', '2', '3', 'd', 'c', 'b'] 3019052845760list1.insert('e')# # Traceback (most recent call last):# # File "C:\Users\liangshu.hu\PycharmProjects\practice\kkkk.py", line 16, in
③ list1.extend(list2)合并两个两个列表(合并list1和list2);【注意】合并后没有产生新的列表对象,且被合并的列表对象依旧存在于内存中。
list1 = ['1', '2', '3']list2 = ['a', 'b', 'c']print(list1, id(list1)) # ['1', '2', '3'] 2568023542464list1.extend(list2)print(list1, id(list1)) # ['1', '2', '3', 'a', 'b', 'c'] 2568023542464print(list2, id(list2)) # ['a', 'b', 'c'] 2568023576896
④ list1+list2 :组合列表:产生一个新的列表对象
list1 = ['1', '2', '3', '4']print(list1, id(list1)) # ['1', '2', '3', '4'] 2912099470144list2 = ['a', 'b', 'c', 'd']print(list2, id(list2)) # ['a', 'b', 'c', 'd'] 2912099504768print(list1+list2, id(list1+list2)) # ['1', '2', '3', '4', 'a', 'b', 'c', 'd'] 2912099787264
⑤ list1*n :重复列表:产生一个新的列表对象
list1 = ['1', '2', '3', '4']print(list1, id(list1)) # ['1', '2', '3', '4'] 2912099470144list2 = list1 * 3print(list2, id(list2)) # ['1', '2', '3', '4', '1', '2', '3', '4', '1', '2', '3', '4'] 3037215854784
三、获取列表中的值
① print(list):返回列表
② for i in list: print i :遍历列表
③ print(list[n]):使用下标索引来获取列表中的某个指定值;同样也可以使用 list[n:m]方式截取字符
④ print(list.count(xx)):查看某个元素在该列表里的数量;如果该元素不存在,那么返回0
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1.count('2')) # 2print(list1.count('q')) # 0
⑤ print(list.index(xx)) :在该列表中找到某个元素的下标索引值;如果该列表中某个元素有多个,则只返回某个元素第一次出现的下标索引值;如果在该列表中查找一个不存在的元素的下标索引值则会报错。(根据列表中的值获取该值所在列表中的下标索引)
a=[72, 56, 76, 84, 80, 88] print(a.index(76)) # 2
但是,list.index(xx) 方法仅仅能获取都第一个匹配value的下标索引值,此时,我们可以使用第二种方案来获取列表元素的下标索引值:利用 enumerate 函数(可以获取列表中所有重复值的下标索引)
list1 = ['a', 'b', 'c', 'a', 'd', '1', '2', '3', 'a']print(enumerate(list1)) #
四、删除列表中的元素
① list.pop() :默认删除列表的最后一个元素;且返回已经删除的元素值
list1 = ['1', '2', '2', '4', 'a', 'b']a = list1.pop()print(list1) # ['1', '2', '2', '4', 'a']print(a) # b
② list.pop(n) :删除列表的指定下标索引位置的元素;如果删除列表中的一个不存在的元素则会报错
list1 = ['1', '2', '2', '4', 'a', 'b']a = list1.pop(0)print(list1) # ['1', '2', '2', '4', 'a']print(a) # 1b = list1.pop(100)print(b)# Traceback (most recent call last):# File "C:\Users\liangshu.hu\PycharmProjects\practice\pksjjdj.py", line 14, in
③ list.remove(xx):删除列表中里面的某个指定元素;如果列表中有多个相同的元素,默认删除第一个出现的元素 ;【注意】每一次只能删除一个列表中的指定元素;
list1 = ['1', '2', '2', '4', 'a', 'b']list1.remove('a')print(list1) # ['1', '2', '2', '4', 'b']list1.remove('2')print(list1) # ['1', '2', '4', 'b']
④ print(list.pop()):有返回值,返回列表中已经被删除的元素
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1.pop()) # b
⑤ print(list.remove()) 无返回值
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1.remove('2')) # None
⑥ del list[n] :删除列表指定下标索引对应的元素【从内存中回收列表的指定元素】
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1, id(list1)) # ['1', '2', '2', '4', 'a', 'b'] 2727783140096del list1[0]print(list1, id(list1)) # ['2', '2', '4', 'a', 'b'] 2727783140096
⑦ del list :删除整个列表,列表删除后无法访问【从内存回收整个列表】
list1 = ['1', '2', '2', '4', 'a', 'b']del list1print(list1, id(list1))# Traceback (most recent call last):# File "C:\Users\liangshu.hu\PycharmProjects\practice\pksjjdj.py", line 11, in
⑧ 无论是 list.pop() 方法还是 list.remove() 方法删除元素后的列表内存地址不变,即列表删除元素操作不会产生一个新列表
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1, id(list1)) # ['1', '2', '2', '4', 'a', 'b'] 2118284184320list1.pop()print(list1, id(list1)) # ['1', '2', '2', '4', 'a'] 2118284184320list1.remove('2')print(list1, id(list1)) # ['1', '2', '4', 'a'] 2118284184320
⑨ list.clear() :清空列表中的元素;但是列表对象仍然存在于内存中。
a = ['Google', 'Runoob', 'Taobao', 'Baidu']b = [1, 2, 3, 4]print("a=", a)print("b=", b)a.clear()b.clear()print("a=", a)print("b=", b)
五、其他
1、判断元素是否存在于列表中
xx in [] :只能判断元素对象是否存在于列表中;不能判断列表的子列表是否存在于列表中。
list1 = ['1', '2', '3', '4', 'a', 'b', 'c']print('1' in list1) # Trueprint(['1', 'a'] in list1) # False
2、比较两个列表的元素
operator.eq(list1,list2) :实现两个列表的比较功能;需要引入 operator 模块,适合于任何对象。
具体查看Python内置模块 operator 模块(python中内置的操作符函数接口)请查看博客:
import operatorprint(operator.eq('hello', 'name')) # Falseprint(operator.eq('hello', 'hello')) # True
六、排序和反转
① list.reverse() :将列表反转;【注意】反转后的列表内存地址不变,既没有产生新的列表对象
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1, id(list1)) # ['1', '2', '2', '4', 'a', 'b'] 2881397492416list1.reverse()print(list1, id(list1)) # ['b', 'a', '4', '2', '2', '1'] 2881397492416
② list.sort() :将列表中的元素排序;默认升序排序;【注意】排序后没有产生新的列表对象
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1, id(list1)) # ['1', '2', '2', '4', 'a', 'b'] 2541629901568list1.sort()print(list1, id(list1)) # ['1', '2', '2', '4', 'a', 'b'] 2541629901568
③ list.sort(reverse=True) :将列表中的元素排序;降序排列;【注意】排序后没有新的列表对象
list1 = ['1', '2', '2', '4', 'a', 'b']print(list1, id(list1)) # ['1', '2', '2', '4', 'a', 'b'] 1998451280640list1.sort(reverse=True)print(list1, id(list1)) # ['b', 'a', '4', '2', '2', '1'] 1998451280640
【注意】:一个列表中同时存在字符串和数字时不能排序;列表的排序是针对某一列表中的同类型数据。
1、sort函数
如果对python中的列表进行排序,可以使用 List 类的成员函数 sort ;该函数会在原空间上进行操作,对列表本身进行修改,不返回副本即不返回新的列表对象。
语法如下:
List.sort(cmp=None, key=None, reverse=False)
2、sorted函数
sorted 函数就比 sort 函数要强大太多;
sort 只能对列表进行排序, sorted 可以对所有可迭代类型进行排序;并且返回新的已排序的列表对象。语法如下:
sorted(iterable, cmp=None, key=None, reverse=False)
可接受4个参数,含义分别如下:
①iterable:可迭代类型,例如字典、列表②cmp:比较函数,cmp是带两个参数的比较函数;key 是带一个参数的函数③key:可迭代类型中某个属性,对给定元素的每一项进行排序④reverse:降序或升序
3、结合使用
与 sorted 函数经常结合使用的有:
①比较函数经常会用到 lambda 匿名函数。
示例:对数个元组组成的列表,以元组中的某一项进行排序。
students = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]sorted(students, key=lambda student : student[2]) # sort by age # [('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
②比较函数经常会用到 operator.itemgetter函数
operator 模块提供的 itemgetter 函数用于获取对象的哪些维的数据,参数为一些序号。
【注意】 operator.itemgetter 函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值。
sorted函数用来排序, sorted(iterable[, cmp[, key[, reverse]]])
key 的参数为一个函数或者 lambda 函数。所以 itemgetter可以用来当 key 的参数。
# 例如根据第二个域和第三个域进行排序 a = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)] sorted(students, key=operator.itemgetter(1,2))
③可迭代元素经常会用到items
items是字典中的一个方法,返回由元组组成的列表。
dict={'a':1,'b':2}ans = sorted(dict.items(), key=lambda x:x[1], reverse=True)
七、列表操作的函数
① len(list) :返回列表元素个数
② max(list) :返回列表元素最大值
③ min(list) :返回列表元素最小值
④ list(tuple) :将元组转换为列表
⑤ enumerate :打印元素对应的下标
list_ = [1, 2, 3, 44, 'abc', 'lkj']for i, v in enumerate(list_): print("value:{},index:{}".format(v, i))结果如下:
value:1,index:0value:2,index:1value:3,index:2value:44,index:3value:abc,index:4value:lkj,index:5
八、列表切片(列表取值的一种方法)
① name[n:m] :切片是不包含后面那个元素的值(顾头不顾尾)
② name[:m] :如果切片前面一个值缺省的话,从开头开始取
③ name[n:] : 如果切片后面的值缺省的话,取到末尾
④ name[:] :如果全部缺省,取全部
⑤ name[n:m:s] :
s表示步长,表示每隔多少个元素取一次列表中的值
步长是正数,从左往右取
步长是负数,从右往左取
【注意】:切片同样适用于字符串,因为字符串也有下标
九、列表生成式
概述:
①列表生成式即 List Comprehensions ,是Python内置的非常简单却强大的可以用来创建列表的生成式。
②列表生成式的结构是在一个中括号里包含一个表达式,然后是一个 for 语句,然后是0个或多个 for 或者 if语句。
③列表表达式可以是任意的,可以在列表中放入任意类型的对象。返回结果将是一个新的列表。
variable = [out_exp for out_exp in input_list if out_exp == 2]
举例:
1. 生成一个列表,列表元素分别为 [1*1,2*2,3*3……n*n] ,假设 n=10 。
①若用一般方法实现代码如下:
list1 = []for i in range(1, 11): list1.append(i * i)
②若用列表生成式:
list2 = [i * i for i in range(1, 11)]
2.字符串 s1 ='ABC' ,字符串 s2 = '123' ,要求:生成一个列表 [A1, A2, A3, B1, B2, B3]
①若用一般方法实现代码如下:
list1 = []for i in 'ABC': for j in '123': list1.append(i+j)
②若用列表生成式:
list2 = [i+j for i in 'ABC' for j in '123']
小总结:
①列表是一个有序的对象集合;且列表可变;在对列表进行一系列操作之后不会创建新的列表,可用 id() 函数对比查看列表的内存地址。
②一个对象在另外一个对象中吗可以用 in 来检查。
③从列表中删除对象使用 remove 函数
remove :取一个对象值作为唯一参数。 remove 方法会从列表中删除指定第一次出现的数据值。【如果在列表中找到了这个数据值,就会从列表中删除包含这个值的对象(同时列表的大小减一)。如果在列表中没有找到这个数据值,会报错。】
④从列表中弹出对象使用 pop 函数 pop :取一个可选的下标索引值(indexof)作为参数。 pop 函数根据对象的下标索引值从现有列表删除并返回一个对象。【如果调用 pop 函数时没有指定元素的下标索引值,将默认删除并返回列表中的最后一个对象。如果指定了一个索引值,则会删除和返回指定位置上的对象。如果列表为空或者调用 pop 函数时指定了一个不存在的元素下标索引值,则会报错。】
⑤用对象扩展列表使用extend 函数 【extend :取一个列表对象作为唯一参数。 extend 方法接收第二个列表,将其中的各个对象增加到现有列表。如果要将两个列表合并为一个列表,这个方法就非常有用。】
⑥在列表中插入一个元素对象 insert/append insert :取一个索引值和一个对象作为参数。 insert 方法将一个对象插入到现有列表中指定下标索引值的前面。这样就可以将元素对象插入到现有列表的开头,或者插入到列表中的任何位置。 append :默认插入元素对象到列表末尾。
⑦如何复制一个列表数据结构?
不要使用赋值操作符复制列表;应当使用copy方法。因为赋值操作都指向同一个数据(并没有产生一个新的列表对象),如果修改复制后的列表,另一个当然也会改变(因为他们是同一个列表对象);【如果想让另一个变量引用一个现有列表,可以使用赋值操作(=)】
copy:list2 = list1.copy() :如果想建立现有列表中对象的副本,初始化一个新列表,就一定要使用copy方法
去期待陌生,去拥抱惊喜。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~