13、Python基本数据类型及内置方法2(列表、元组、字典)

一、列表

1.1 列表是什么

  在[]内,用逗号分隔开多个任意数据类型的值。

l1 = [1,'a',[1,2]]  # 本质:l1 = list([1,'a',[1,2]])

1.2 类型转换

  但凡能被for循环遍历的数据类型都可以传给list()转换成列表类型,list()会跟for循环一样遍历出数据类型中包含的每一个元素然后放到列表中。

>>> list('wdad') # 结果:['w', 'd', 'a', 'd'] ,字符串会被转换成独立的字符的列表
>>>list({'k1':111,'k2':222,'k3':3333}) # 结果:['k1', 'k2', 'k3'] ,字典会转换为变量名的列表

1.3 如何使用?

## 1.3.1 重要的使用方法:

# 1.按索引存取值(正向存取+反向存取):即可存也可以取  
# 1.1 正向取(从左往右)
>>> l=[111,'abc','hello']
>>> l[0]  
111
# 1.2 反向取(负号表示从右往左)
>>>  l[-1]  
hello
# 1.3 对于list来说,既可以按照索引取值,又可以按照索引修改指定位置的值,但如果索引不存在则报错
>>> l=[111,'abc','hello']
>>> l[0]=222
>>> print(l)
[222,'abc','hello']

l[3]=333 # IndexError: list assignment index out of range 赋值不存在,报错

# 2.往列表内添加值
# 2.1 追加 append()列表尾部追加元素
>>> l1 = ['a','b','c']
>>> l1.append('d')
>>> l1
['a', 'b', 'c', 'd']

# 2.2  插入 insert()在指定位置插入元素
>>> l1.insert(0,"first")  # 0表示在索引位置0处插值
>>> l1
['first', 'a', 'b', 'c', 'alisa', 'a', 'b', 'c']

# 2.3 扩展 extend()一次性在列表尾部添加多个元素
>>> l1.extend(['a','b','c'])
>>> l1
['a', 'b', 'c', 'd', 'a', 'b', 'c']

# 3.删除
# 3.1 del  通用的删除方法,只是单纯的删除,没有返回值
>>> l = [11,22,33,44]
>>> del l[2]  # 删除索引为2的元素
>>> l
[11,22,44]

# 3.2 pop() 索引删除,默认删除列表最后一个元素,并将删除的值返回,括号内可以通过加索引值来指定删除元素
>>> l = [11,22,33,22,44]
>>> res=l.pop()
>>> res
44
>>> res=l.pop(1)
>>> res
22

# 3.3 remove()根据元素删除,没有返回值,返回值为None
>>> l = [11,22,33,22,44]
>>> res=l.remove(22) # 从左往右查找第一个括号内需要删除的元素
>>> print(res)
None

# 4.切片(顾头不顾尾,步长)
# 4.1 顾头不顾尾:取出索引为0到3的元素
>>> l=[111,'abc','hello',222]
>>>l[0:3] 
[111,'abc','hello']
# 4.2 步长:0:3:2,第三个参数2代表步长,会从0开始,每次累加一个2即可,所以会取出索引0、2的元素
>>> l=[111,'abc','hello',222] 
>>>l[0:3:2]
[111,'hello']
不指定开始于结尾,默认全部取出,是一种拷贝行为,相当于浅拷贝
>>>l[:]  # 同等操作于l[0:len(l)]
[111,'abc','hello',222]
>>>l[::-1]  # 快速把列表数据全部倒过来
[222,'hello','abc',111]

# 5.长度  统计列表的元素的个数
>>> len(l)
4

# 6.成员运算in和not in
判断元素是否在列表中

# 7.for循环,遍历列表里面的值
for x in [111,'abc','hello']:
    print(x) 
111
'abc'
'hello'

## 1.3.2 次要的使用方法:

# 1.  l.count() 统计元素在列表中的出现的次数
>>>l=[111,'abc','hello']
>>>print(l.count('abc'))
1

# 2.   l.index()
>>>print(l.index('abc'))  寻找元素在列表中第一次出现的位置
2
>>>print(l.index('abcdd'))  # 找不到会报错

# 3.  l.clear()  #  清空列表
>>> l=[111,'abc','hello']
>>> l.clear()  #  清空原列表
[]

# 4.  l.reverse()  # 不是排序,颠倒列表内元素顺序
>>> l=[111,'abc','hello']
>>> l.reverse()  # 颠倒
['hello', 'abc', 111]

# 5. sort()给列表内所有元素排序
# 5.1 排序时列表元素之间必须是相同数据类型,不可混搭,否则报错
>>> l = [11,22,3,42,7,55]
>>> l.sort()
>>> l 
[3, 7, 11, 22, 42, 55]  # 默认从小到大排序
>>> l = [11,22,3,42,7,55]
>>> l.sort(reverse=True)  # reverse用来指定是否颠倒排序,默认为False
>>> l 
[55, 42, 22, 11, 7, 3]

## 1.3.3 了解知识:

# 常用的数字类型可以直接比较大小,但其实,字符串、列表等都可以比较大小,原理相同:都是依次比较对应位置的元素的大小,如果分出大小,则无需比较下一个元素,比如
>>> l1=[1,2,3]
>>> l2=[2,]
>>> l2 > l1
True
# 字符之间的大小取决于它们在ASCII表中的先后顺序,越往后越大
>>> s1='abc'
>>> s2='az'
>>> s2 > s1 # s1与s2的第一个字符没有分出胜负,但第二个字符'z'>'b',所以s2>s1成立
True
# 所以我们也可以对下面这个列表排序
>>> l = ['A','z','adjk','hello','hea']
>>> l.sort()
>>> l
['A', 'adjk', 'hea', 'hello','z']

## 1.3.4 补充

# 1、队列 :FIFO,先进先出
>>>l=[]
 入队操作
>>>l.append("first")
>>> l.append("second")
>>>l.append("third")
['first', 'second', 'third']
 出队操作
>>>print(l.pop(0))
first
>>>print(l.pop(0))
second
>>>print(l.pop(0))
third

# 2、堆栈:LIFO,后进先出
l=[]
# 入栈操作
>>>l.append('first')
>>>l.append('second')
>>>l.append('third')
['first', 'second', 'third']
# 出队操作
>>>print(l.pop())
third
>>>print(l.pop())
second
>>>print(l.pop())
first

二、元组

2.1 元组的是什么

  元组就是在()内用逗号分隔开多个任意类型的值的集合。
  元组与列表类似,也是可以存多个任意类型的元素,不同之处在于元组的元素不能修改,即元组相当于不可变的列表,按照索引/位置记录多个固定不允许修改的值,只读、不能取。
  如果元组内只有一个值,则必须加一个逗号,否则()就只是包含的意思而非定义元组.

2.2 类型转换

  但凡能被for循环的遍历的数据类型都可以传给tuple()转换成元组类型,tuple()会跟for循环一样遍历出数据类型中包含的每一个元素然后放到元组中。

>>> tuple('wdad') # 结果:('w', 'd', 'a', 'd') 
>>> tuple({"name":"jason","age":18}}) # 结果:('name', 'age'),字典会转换为变量名的元组

2.3 如何使用?

## 2.3.1 重要的使用方法:

# 1.按索引存取值(正向存取+反向存取):即可存也可以取  
# 1.1 正向取(从左往右)
>>> t=(111,'abc','hello')
>>> t(0)  
111
# 1.2 反向取(负号表示从右往左)
>>>  t(-1)  
hello

# 2.切片(顾头不顾尾,步长)
# 2.1 顾头不顾尾:取出索引为0到3的元素
>>> t=(111,'abc','hello',222)
>>>t(0:3) 
(111,'abc','hello')
# 2.2 步长:0:3:2,第三个参数2代表步长,会从0开始,每次累加一个2即可,所以会取出索引0、2的元素
>>> t=(111,'abc','hello',222) 
>>>t(0:3:2)
(111,'hello')

>>>t(:)  # 同等操作于t(0:len(t))
(111,'abc','hello',222)
>>>t(::-1)  # 快速把元组数据全部倒过来
(222,'hello','abc',111)

# 3.长度  统计元组的元素的个数
>>> len(t)
4

# 4.成员运算in和not in
判断元素是否在元组中

# 5.for循环,遍历列表里面的值
for x in (111,'abc','hello'):
    print(x) 
111
'abc'
'hello'

猜你喜欢

转载自www.cnblogs.com/zuiyouyingde/p/12465157.html