Python全栈之列表数据类型详解
前言
列表(list)同字符串一样都是有序的,因为他们都可以通过切片和索引进行数据访问,且列表是可变的。
创建列表的几种方法
第一种
name_list = ['Python', 'PHP', 'JAVA']
第二种
name_list = list(['Python', 'PHP', 'JAVA'])
创建一个空列表
>>> li = list() >>> type(li) <class 'list'>
把一个字符串转换成一个列表
>>> var="abc" >>> li = list(var) >>> li ['a', 'b', 'c']
list在把字符串转换成列表的时候,会把字符串用for循环迭代一下,然后把每个值当作list的一个元素。
把一个元组转换成列表
>>> tup=("a","b","c") >>> li=list(tup) >>> type(li) <class 'list'> >>> li ['a', 'b', 'c']
把字典转换成列表
>>> dic={"k1":"a","k2":"b","k3":"c"} >>> li=list(dic) >>> type(li) <class 'list'> >>> li ['k3', 'k1', 'k2']
字典默认循环的时候就是key,所以会把key当作列表的元素
>>> dic={"k1":"a","k2":"b","k3":"c"} >>> li=list(dic.values()) >>> li ['c', 'a', 'b']
如果指定循环的是values,那么就会把values当作列表的元素
列表所提供的方法
在列表末尾添加新的对象
append(self, p_object):
>>> name_list = ['Python', 'PHP', 'JAVA'] >>> name_list.append("C#") >>> name_list ['Python', 'PHP', 'JAVA', 'C#']
统计某个元素在列表中出现的次数
count(self, value):
属性 | 描述 |
---|---|
obj | 列表中统计的对象 |
>>> name_list = ['Python', 'PHP', 'PHP'] >>> name_list.count("PHP") 2
用于在列表末尾一次性追加另一个序列中的多个值
extend(self, iterable):
属性 | 描述 |
---|---|
seq | 元素列表 |
>>> name_list = ['Python', 'PHP', 'Python'] >>> name_OS = ['Windows', 'Linux', 'Unix'] >>> name_list ['Python', 'PHP', 'Python'] >>> name_OS ['Windows', 'Linux', 'Unix'] # 把列表`name_OS`中的内容添加到`name_list`的尾部 >>> name_list.extend(name_OS) # 输出的结果 >>> name_list ['Python', 'PHP', 'Python', 'Windows', 'Linux', 'Unix']
从列表中找出某个值第一个匹配项的索引位置
index(self, value, start=None, stop=None):
属性 | 描述 |
---|---|
value | 列表中统计的对象 |
# 查找对象所在的位置 >>> name_list = ['Python', 'PHP', 'JAVA'] >>> name_list.index("PHP") 1
将指定对象插入列表
insert(self, index, p_object):
属性 | 描述 |
---|---|
index | 对象obj需要插入的索引位置 |
obj | 要出入列表中的对象 |
>>> name_list = ['Python', 'PHP', 'JAVA'] # 把位置`1`的内容换成`C`,后面的自动退格一个位置 >>> name_list.insert(1,"C") >>> name_list ['Python', 'C', 'PHP', 'JAVA']
移除列表中的一个元素,并且返回该元素的值
pop(self, index=None):
属性 | 描述 |
---|---|
index | 可选参数,要移除列表元素的位置 |
>>> name_list = ['Python', 'PHP', 'JAVA'] # 删除位置1上面的内容,并且返回删除的字符串 >>> name_list.pop(1) 'PHP' >>> name_list ['Python', 'JAVA']
移除列表中某个值的第一个匹配项
remove(self, value):
属性 | 描述 |
---|---|
value | 列表中要移除的对象 |
>>> name_list = ['Python', 'PHP', 'JAVA', 'Python'] # 每次删除的时候只会把第一次匹配到的值删除,第二个值不会被删除 >>> name_list.remove("Python") >>> name_list ['PHP', 'JAVA', 'Python'] >>> name_list.remove("Python") >>> name_list ['PHP', 'JAVA']
当然删除元素还可以直接使用del进行删除:
>>> L = [1,2,3] >>> del L[1] >>> L [1, 3]
又或者使用切片赋值进行元素删除
>>> L = [1,2,3] >>> L[1:2] = [] >>> L [1, 3]
反向输出列表中的元素
reverse(self):
>>> name_list = ['Python', 'PHP', 'JAVA'] >>> name_list ['Python', 'PHP', 'JAVA'] >>> name_list.reverse() >>> name_list ['JAVA', 'PHP', 'Python']
对原列表进行排序,如果指定参数,则使用比较函数指定的比较函数
sort(self, cmp=None, key=None, reverse=False):
>>> name_list = ['Python', 'PHP', 'JAVA'] >>> name_list ['Python', 'PHP', 'JAVA'] >>> name_list.sort() >>> name_list ['JAVA', 'PHP', 'Python']
清除列表内所有元素
>>> li ['Ansheng'] >>> li.clear() >>> li []
同字符串一样,列表也支持解析,称为列表解析
>>> li = [x for x in range(1,20)] >>> li [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
相关文章
python Pandas库read_excel()参数实例详解
人们经常用pandas处理表格型数据,时常需要读入excel表格数据,下面这篇文章主要给大家介绍了关于python Pandas库read_excel()参数的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-07-07详解从Django Rest Framework响应中删除空字段
这篇文章主要介绍了详解从Django Rest Framework响应中删除空字段,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-01-01
最新评论