码迷,mamicode.com
首页 > 编程语言 > 详细

Python(6)--列表

时间:2018-11-24 21:09:31      阅读:211      评论:0      收藏:0      [点我收藏+]

标签:list   关联   xtend   sig   对象   接收   recent   照相   none   

列表:

  序列中已经使用了列表

  列表是用[]定义的序列,[]内包含0个或者多个元素

  列表是可变的,可以修改其内容

 


 

函数list:

  将序列作为list函数的参数,常见列表

#字符串创建列表
>>> s = "hello"
>>> l = list(s)
>>> l
[‘h‘, ‘e‘, ‘l‘, ‘l‘, ‘o‘]


# 列表转换为字符串
>>> "".join(l)
‘hello‘

  


 列表基本操作:

  列表可以执行所有的标准序列操作:Python(5)--数据结构-序列-通用操作

  修改列表:

  1、元素赋值

# 使用索引给特定的元素赋值
>>> s = [1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> s[2] = "a"
>>> s
[1, 2, ‘a‘, 4, 5, 6, 7, 8, 9]

# 不能给不存在的元素赋值
>>> s[10] = "b"
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
IndexError: list assignment index out of range

  2、删除元素

# 使用del语句删除元素
>>> s
[1, 2, ‘a‘, 4, 5, 6, 7, 8, 9]
>>> del s[6]
>>> s
[1, 2, ‘a‘, 4, 5, 6, 8, 9]

  3、切片赋值

# 给多个元素赋值
>>> a = list("python")
>>> a
[‘p‘, ‘y‘, ‘t‘, ‘h‘, ‘o‘, ‘n‘]
>>> a[3:] = list("xxx")
>>> a
[‘p‘, ‘y‘, ‘t‘, ‘x‘, ‘x‘, ‘x‘]

# 替换不同长度的序列
>>> a = list("python")
>>> a
[‘p‘, ‘y‘, ‘t‘, ‘h‘, ‘o‘, ‘n‘]
>>> a[1:] = list("z")
>>> a
[‘p‘, ‘z‘]

# 不替换原有元素下插入新元素,使用[1:1]得到是空切片,通过替换它来插入
>>> a
[‘p‘, ‘z‘]
>>> a[1:1]
[]
>>> a[1:1] = [6, 6, 6]
>>> a
[‘p‘, 6, 6, 6, ‘z‘]

# 删除,使用空序列来替换
>>> a
[‘p‘, 6, 6, 6, ‘z‘]
>>> a[1:4] = []
>>> a
[‘p‘, ‘z‘]

  


 

列表方法:  

append方法,将一个对象追加到列表末尾

>>> a
[‘p‘, ‘z‘]
>>> a.append(6)
>>> a
[‘p‘, ‘z‘, 6]

 

clear方法就地清空列表

>>> a
[‘p‘, ‘z‘, 6]
>>> a.clear()
>>> a
[]

  

copy方法赋值列表

# 常规的复制只是将另一个名字关联到列表,也就是两个名字指向同一个列表
>>> a = [1, 2, 3]
>>> b = a
>>> b[1] = "a"
>>> a
[1, ‘a‘, 3]
>>> b
[1, ‘a‘, 3]

# 如果要让a和b指向不同的列表,需要将b关联到a的副本,跟a[:]和list(a)类似,都是赋值a
>>> a = [1, 2, 3]
>>> b = a.copy()
>>> b[1] = "a"
>>> a
[1, 2, 3]
>>> b
[1, ‘a‘, 3]

  

count方法计算指定元素在列表中出现的次数

>>> a = [1, 2, 3, 2,2,1,2]
>>> a.count(2)
4
>>> a = ["a", [1,2], 1, 2, [1, 2]]
>>> a.count([1, 2])
2

  

extend方法使用一个列表来扩展另一个列表

>>> a = [1, 2, 3]
>>> b = ["a", "b"]
>>> a.extend(b)
>>> a
[1, 2, 3, ‘a‘, ‘b‘]

# 看着跟拼接差不多,但是拼接是不会修改原来的列表的,是返回一个新列表
>>> a = [1, 2, 3]
>>> b = ["a", "b"]
>>> a + b
[1, 2, 3, ‘a‘, ‘b‘]
>>> a
[1, 2, 3]

  

index方法在列表中查找指定元素第一次出现的索引,找不到会报错

>>> a = [1, 2, 3, 2,2,1,2]
>>> a.index(2)
1
>>> a.index("a")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: ‘a‘ is not in list

  

insert方法用于将一个对象插入列表

>>> a = [1, 2, 3, 2,2,1,2]
>>> a.insert(3, "aaa")
>>> a
[1, 2, 3, ‘aaa‘, 2, 2, 1, 2]

  

pop方法从列表删除一个元素,默认为最后一个,可以指定索引,并返回这个元素

pop是唯一既修改列表又返回一个非None值的列表方法

>>> a
[1, 2, 3, ‘aaa‘, 2, 2, 1, 2]
>>> a.pop()
2
>>> a
[1, 2, 3, ‘aaa‘, 2, 2, 1]
>>> a.pop(3)
‘aaa‘
>>> a
[1, 2, 3, 2, 2, 1]

  

remove方法用于删除第一个为指定值的元素

修改列表但是不返回值

>>> a
[1, 2, 3, 2, 2, 1]
>>> a.remove(2)
>>> a
[1, 3, 2, 2, 1]

  

reverse方法将列表元素顺序反转,修改列表不反悔任何值

>>> a
[1, 3, 2, 2, 1]
>>> a.reverse()
>>> a
[1, 2, 2, 3, 1]

# reversed安相反的顺序迭代序列,返回的是一个迭代器,可以使用list将返回的对象转换为列表
>>> a
[1, 2, 2, 3, 1]
>>> list(reversed(a))
[1, 3, 2, 2, 1]

  

sort方法用于对列表就地排序

sorted用于讲一个序列排序,返回一个列表

>>> x = [4, 7, 5, 2, 1, 9]
>>> x.sort()
>>> x
[1, 2, 4, 5, 7, 9]

# 如果想要保留原来的xulie,方法一是:先将y关联到x的副本,在对y进行排序
>>> x = [4, 7, 5, 2, 1, 9]
>>> y = x.copy()
>>> y.sort()
>>> x
[4, 7, 5, 2, 1, 9]
>>> y
[1, 2, 4, 5, 7, 9]

# 方法二是:使用函数sorted,sorted可以用于任何序列,返回的始终是一个列表
>>> x = [4, 7, 5, 2, 1, 9]
>>> y = sorted(x)
>>> x
[4, 7, 5, 2, 1, 9]
>>> y
[1, 2, 4, 5, 7, 9]

>>> x = "python"
>>> sorted(x)
[‘h‘, ‘n‘, ‘o‘, ‘p‘, ‘t‘, ‘y‘]

  高级排序:sort和sorted的参数

# 方法sort接受两个可选参数:key和reverse。
# key可以设置为一个用于排序的函数,使用这个函数为每个元素创建一个键,再根据这些键进行排序,比如要根据元素长度排序,将key设置为函数len
>>> x = ["a","ddd","vv","asdfg"]
>>> x.sort(key=len)
>>> x
[‘a‘, ‘vv‘, ‘ddd‘, ‘asdfg‘]

# reverse可以指定为True或者False,指出是否按照相反的顺序排序
>>> x = ["a","ddd","vv","asdfg"]
>>> x.sort(key=len, reverse=True)
>>> x
[‘asdfg‘, ‘ddd‘, ‘vv‘, ‘a‘]

# 函数sorted也接收这两个参数
>>> x = ["a","ddd","vv","asdfg"]
>>> sorted(x, key=len)
[‘a‘, ‘vv‘, ‘ddd‘, ‘asdfg‘]
>>> sorted(x, key=len, reverse= True)
[‘asdfg‘, ‘ddd‘, ‘vv‘, ‘a‘]

  

 

Python(6)--列表

标签:list   关联   xtend   sig   对象   接收   recent   照相   none   

原文地址:https://www.cnblogs.com/Mr-chenshuai/p/10012900.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!