切片元组字典知识点

索引:

切片

循环遍历的两种方式

传递

元组

字典

查找

值 = 字典[键]

1,字典.get(键,[默认值])

2,len(字典)计算字典元素个数,即键的总数

3,str(字典)输出字典可打印的字符串表示

4,dict.keys()以列表返回一个字典所有的键

5,dict.values()以列表返回一个字典所有的值

6,dict.items()                以列表返回可遍历的(键, 值) 元组数组

修改和新增

字典[键]=值

删除

字典.pop(键)

del 字典[键]

字典.clear()

遍历字典的方法

1,dict.items()

2,根据“值 = 字典[键]”直接输出

3,根据字典的每一项(即每一个键值对)都是一个列表,遍历每个列表,然后输出

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

正文

列表切片

import math ls=[float('%0.3f'%math.sqrt(i)) for i in range(0,10) ]

print(ls)

切片

ls[a:b:c]

a默认=0

b默认=len(ls)

c默认=1

&*&*&*&**&*&*&*

c=-1时,就是倒序的ls例:ls[::-1]  <==>    ls.reverse()

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

循环遍历的两种方式:

一、用while循环ls=[i**2 for i in range(0,19)]j=0while ja=20

print(b)  ==>b=10

ls1=[i for i in range(0,19)]

ls2=ls1

ls1.append(1)

print(ls1)  ==>ls1=[i for i in range(0,19)]+[1]

print(ls2)  ==>ls2=[i for i in range(0,19)]+[1]

传递后,一方改变,对另一方的影响:

1,如果是普通类型(数字、字符串、布尔、空),

另一方不受影响    ==>值传递

2,如果是非普通类型,

另一方会随之改变  ==>引用传递

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

元组

元组是一个特殊的列表。只读,不能修改。

一旦定义并赋值之后,不能再修改了。

只有查询的功能

需要注意的两点:

一,单元素元组的写法

tu1=(1,)和tu2=(1)的格式不一样,type(tu1)是tuple,type(tu2)是int

如果元组只有一个值,需要后面加逗号。

建议:

元组、列表,最后都加一个逗号

二,若元组中元素为列表时,

列表里面的内容可以更改

例:

nums = (1,2,3,[44,55,66])

nums[3][1] = 555

print(nums)  ==>nums=(1, 2, 3, [44, 555, 66])

反例:

nums = (1,2,3,[44,55,66])

nums[3] = [44,55,66]

这个操作则无法运行,如同:

ls1=[i for i in range(0,19)]

ls2=ls1

ls1=[i for i in range(0,9)]

print(ls1)==>ls1=[i for i in range(0,9)]

print(ls2)==>ls2=[i for i in range(0,9)]

违背了传递的总结的结论,

原因都是变量改变了地址导致

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

列表和元组相互转换

列表 = list(元组)

元组转列表

元组 = tuple(列表)

列表转元组

&*&*&*&

列表可以直接[i for i in range(0,9)]

用范围值定义,元组不可以这样

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

字典

Python内置了字典:dict的支持,dict全称dictionary

语法:

标识符 = {'键1':值1,'键1':值2...}

注意:

1、键必须是字符串,值是任何类型的

2、键必须是唯一的,值可以重复

3、如果键重复了,后面会覆盖前面的

infos = {

'sid':110,

'sname':'老王',

'age':22,

'hobby':['抽烟','喝酒','烫头发']

}

print(infos['sname'])

print(infos['hobby'][2])

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

查找

字典的键是无序的

值 = 字典[键] 根据键查询值

1,字典.get(键,[默认值])

通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value

2,len(字典) 计算字典元素个数,即键的总数。

3,str(字典) 输出字典可打印的字符串表示。

4,dict.keys() 以列表返回一个字典所有的键

5,dict.values() 以列表返回一个字典所有的值

6,dict.items() 以列表返回可遍历的(键, 值) 元组数组

#获取所有的键

keys1 = infos.keys()

print(keys1)  ==>输出结果为列表形式

即:

print(keys1)  ==>dict_keys(['hobby', 'age', 'sid', 'sname'])

#遍历键

for i in keys1:

print(i)

#获取所有的值

values1 = infos.values()

print(values1)  ==>输出结果为列表形式

即:dict_values([110, 22, '老王', ['抽烟', '喝酒', '烫头发']])

#遍历值

for i in values1:

print(i)

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

修改和新增

如果存在这样的键,是修改

否则是新增

infos = {

'sid':110,

'sname':'老王',

'age':22,

'hobby':['抽烟','喝酒','烫头发']

}

#修改

infos['age'] = 99

print(infos)

#新增

infos['sex'] = '男'

print(infos)

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

删除

字典.pop(键)

根据键,删除指定的值,并将此值放回

del 字典[键]

根据键,删除指定的值

字典.clear()

清空字典里的键值对

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

判断某个键是不是在字典里面

语法:键 in 字典

如果键在字典中存在,返回True

否则,返回False

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

遍历字典的方法

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

第一种:

print(infos.items())

输出结果为:

dict_items([('sid', 110), ('hobby', ['抽烟', '喝酒', '烫头发']), ('sname', '老王'), ('age', 22)])

这样只是把字典打印出来,显得很乱

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

第二种:

原理:根据“值 = 字典[键]”

for k in infos:

print('%s:%s'%(k,infos[k]))

输出结果:

hobby:['抽烟', '喝酒', '烫头发']

age:22

sid:110

sname:老王

简单明了

print('&&&&&&&&&&&&&&&&&&&&&&&&&&&&假装这不是分割线&&&&&&&&&&&&&&&&&&&&')

第三种:用for遍历列表的方法,

原理:字典的每一项(即每一个键值对)都是一个列表

infos_items=字典的每个键值对

for i in infos_items:

#print('i=%s'%str(i))

key = i[0]

value = i[1]

print('%s:%s'%(key,value))

输出结果:

sid:110

age:22

hobby:['抽烟', '喝酒', '烫头发']

sname:老王

不如第二种方法简便

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容