美文网首页程序员
切片元组字典知识点

切片元组字典知识点

作者: 步_尘 | 来源:发表于2017-10-31 20:26 被阅读0次

    索引:

    切片

    循环遍历的两种方式

    传递

    元组

    字典

    查找

    值 = 字典[键]

    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:老王

    不如第二种方法简便

    相关文章

      网友评论

        本文标题:切片元组字典知识点

        本文链接:https://www.haomeiwen.com/subject/beqipxtx.html