Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >python入门到放弃(七)-基本数据类型之dcit字典

python入门到放弃(七)-基本数据类型之dcit字典

作者头像
老油条IT记
发布于 2020-03-20 13:07:50
发布于 2020-03-20 13:07:50
61200
代码可运行
举报
运行总次数:0
代码可运行

1.概述

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
字典是python中唯一的一个映射类型,以{}大括号括起来的键值对组成

字典中的key是唯一的,必须是可hash,不可变的数据类型

语法:{key1:value,key2:value}

#扩展:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
可哈希(不可变)的数据类型:int,str,tuple,bool
不可哈希(可变)的数据类型:list,dict,set

#先来看看dict字典的源码写了什么,方法:按ctrl+鼠标左键点dict

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class dict(object):
    """
    dict() -> new empty dictionary
    dict(mapping) -> new dictionary initialized from a mapping object's
        (key, value) pairs
    dict(iterable) -> new dictionary initialized as if via:
        d = {}
        for k, v in iterable:
            d[k] = v
    dict(**kwargs) -> new dictionary initialized with the name=value pairs
        in the keyword argument list.  For example:  dict(one=1, two=2)
    """

    def clear(self): # real signature unknown; restored from __doc__
        """ 清除内容 """
        """ D.clear() -> None.  Remove all items from D. """
        pass

    def copy(self): # real signature unknown; restored from __doc__
        """ 浅拷贝 """
        """ D.copy() -> a shallow copy of D """
        pass

    @staticmethod # known case
    def fromkeys(S, v=None): # real signature unknown; restored from __doc__
        """
        dict.fromkeys(S[,v]) -> New dict with keys from S and values equal to v.
        v defaults to None.
        """
        pass

    def get(self, k, d=None): # real signature unknown; restored from __doc__
        """ 根据key获取值,d是默认值 """
        """ D.get(k[,d]) -> D[k] if k in D, else d.  d defaults to None. """
        pass

    def has_key(self, k): # real signature unknown; restored from __doc__
        """ 是否有key """
        """ D.has_key(k) -> True if D has a key k, else False """
        return False

    def items(self): # real signature unknown; restored from __doc__
        """ 所有项的列表形式 """
        """ D.items() -> list of D's (key, value) pairs, as 2-tuples """
        return []

    def iteritems(self): # real signature unknown; restored from __doc__
        """ 项可迭代 """
        """ D.iteritems() -> an iterator over the (key, value) items of D """
        pass

    def iterkeys(self): # real signature unknown; restored from __doc__
        """ key可迭代 """
        """ D.iterkeys() -> an iterator over the keys of D """
        pass

    def itervalues(self): # real signature unknown; restored from __doc__
        """ value可迭代 """
        """ D.itervalues() -> an iterator over the values of D """
        pass

    def keys(self): # real signature unknown; restored from __doc__
        """ 所有的key列表 """
        """ D.keys() -> list of D's keys """
        return []

    def pop(self, k, d=None): # real signature unknown; restored from __doc__
        """ 获取并在字典中移除 """
        """
        D.pop(k[,d]) -> v, remove specified key and return the corresponding value.
        If key is not found, d is returned if given, otherwise KeyError is raised
        """
        pass

    def popitem(self): # real signature unknown; restored from __doc__
        """ 获取并在字典中移除 """
        """
        D.popitem() -> (k, v), remove and return some (key, value) pair as a
        2-tuple; but raise KeyError if D is empty.
        """
        pass

    def setdefault(self, k, d=None): # real signature unknown; restored from __doc__
        """ 如果key不存在,则创建,如果存在,则返回已存在的值且不修改 """
        """ D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D """
        pass

    def update(self, E=None, **F): # known special case of dict.update
        """ 更新
            {'name':'alex', 'age': 18000}
            [('name','sbsbsb'),]
        """
        """
        D.update([E, ]**F) -> None.  Update D from dict/iterable E and F.
        If E present and has a .keys() method, does:     for k in E: D[k] = E[k]
        If E present and lacks .keys() method, does:     for (k, v) in E: D[k] = v
        In either case, this is followed by: for k in F: D[k] = F[k]
        """
        pass

    def values(self): # real signature unknown; restored from __doc__
        """ 所有的值 """
        """ D.values() -> list of D's values """
        return []

    def viewitems(self): # real signature unknown; restored from __doc__
        """ 所有项,只是将内容保存至view对象中 """
        """ D.viewitems() -> a set-like object providing a view on D's items """
        pass

    def viewkeys(self): # real signature unknown; restored from __doc__
        """ D.viewkeys() -> a set-like object providing a view on D's keys """
        pass

    def viewvalues(self): # real signature unknown; restored from __doc__
        """ D.viewvalues() -> an object providing a view on D's values """
        pass

    def __cmp__(self, y): # real signature unknown; restored from __doc__
        """ x.__cmp__(y) <==> cmp(x,y) """
        pass

    def __contains__(self, k): # real signature unknown; restored from __doc__
        """ D.__contains__(k) -> True if D has a key k, else False """
        return False

    def __delitem__(self, y): # real signature unknown; restored from __doc__
        """ x.__delitem__(y) <==> del x[y] """
        pass

    def __eq__(self, y): # real signature unknown; restored from __doc__
        """ x.__eq__(y) <==> x==y """
        pass

    def __getattribute__(self, name): # real signature unknown; restored from __doc__
        """ x.__getattribute__('name') <==> x.name """
        pass

    def __getitem__(self, y): # real signature unknown; restored from __doc__
        """ x.__getitem__(y) <==> x[y] """
        pass

    def __ge__(self, y): # real signature unknown; restored from __doc__
        """ x.__ge__(y) <==> x>=y """
        pass

    def __gt__(self, y): # real signature unknown; restored from __doc__
        """ x.__gt__(y) <==> x>y """
        pass

    def __init__(self, seq=None, **kwargs): # known special case of dict.__init__
        """
        dict() -> new empty dictionary
        dict(mapping) -> new dictionary initialized from a mapping object's
            (key, value) pairs
        dict(iterable) -> new dictionary initialized as if via:
            d = {}
            for k, v in iterable:
                d[k] = v
        dict(**kwargs) -> new dictionary initialized with the name=value pairs
            in the keyword argument list.  For example:  dict(one=1, two=2)
        # (copied from class doc)
        """
        pass

    def __iter__(self): # real signature unknown; restored from __doc__
        """ x.__iter__() <==> iter(x) """
        pass

    def __len__(self): # real signature unknown; restored from __doc__
        """ x.__len__() <==> len(x) """
        pass

    def __le__(self, y): # real signature unknown; restored from __doc__
        """ x.__le__(y) <==> x<=y """
        pass

    def __lt__(self, y): # real signature unknown; restored from __doc__
        """ x.__lt__(y) <==> x<y """
        pass

    @staticmethod # known case of __new__
    def __new__(S, *more): # real signature unknown; restored from __doc__
        """ T.__new__(S, ...) -> a new object with type S, a subtype of T """
        pass

    def __ne__(self, y): # real signature unknown; restored from __doc__
        """ x.__ne__(y) <==> x!=y """
        pass

    def __repr__(self): # real signature unknown; restored from __doc__
        """ x.__repr__() <==> repr(x) """
        pass

    def __setitem__(self, i, y): # real signature unknown; restored from __doc__
        """ x.__setitem__(i, y) <==> x[i]=y """
        pass

    def __sizeof__(self): # real signature unknown; restored from __doc__
        """ D.__sizeof__() -> size of D in memory, in bytes """
        pass

    __hash__ = None

dict

#演示什么数据类型能作为key

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# dic = {'name':'guoke','age':22} #字符串可以为键(key)

# dic = {1:'a',2:'b',3:'c'} #数字可以为键

# dic = {True:'1',False:'2'} #布尔值可以为键

# dic = {(1,2,3):'abc'} #元组也可以为键

# dic = {[1,2,3]:'abc'} #列表不能为键{key:vaule} 

2.字典的增删改查

#2.1增加

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#关键字
# 1、setdefault('键','值')
# 2、变量['key'] = 'value'

#例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dic = {'广东':'广州','山东':'济南','海南':'三亚'}
dic['湖南'] = '长沙' #新增,前面是key,后面是值
print(dic)
#{'广东': '广州', '山东': '济南', '海南': '三亚', '湖南': '长沙'}

dic.setdefault('广西','桂林')
# 使用setdefault需要注意的是如果在字典中存在就不进行任何操作,不存在就进行添加
print(dic)
#{'广东': '广州', '山东': '济南', '海南': '三亚', '广西': '桂林'}

#2.2删除

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#关键字
1、pop()
2、del dic[''] #
3、clear()   #清空
4、popitem  #随机删除
5、要注意的是字典没有remove这个删除命令

#例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dic = {'广东':'广州','山东':'济南','海南':'三亚'}

ret = dic.pop('广东')  #通过key删除,返回被删除的value
print(ret) #广州 :可以查看到的是通过key将值为广州删除了
print(dic) #{'山东': '济南', '海南': '三亚'}

del dic['山东']  #要注意删的时候只能是写key,不能写value删
print(dic) #{'广东': '广州', '海南': '三亚'}

dic.clear()  #{}  #清空
print(dic) #{}

ret = dic.popitem()  #随机删除,返回值 一个元组(key,value)
print(ret) #('海南', '三亚')
print(dic) #{'广东': '广州', '山东': '济南'}

#2.3.修改

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#关键字
1、dic['键'] = '值'
2、dic.update(dic1)

#例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dic = {'广东':'广州','山东':'济南','海南':'三亚'}

dic["广东"] = '湖北' 
#需要注意的是前边的修改是键key,然后等号后面修改的value值
print(dic) #{'广东': '湖北', '山东': '济南', '海南': '三亚'}

dic1 = {'战狼':'吴京','亮剑':'李云龙','山东':'淮上'}
dic.update(dic1)
print(dic)
#{'广东': '湖北', '山东': '淮上', '海南': '三亚', '战狼': '吴京', '亮剑': '李云龙'}
#把dic1中的内容更新到dic中,如果key重名,则修改替换,如果不存在key,则新增

#2.4.查询

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 关键字
# 1、使用for循环获取,获取到的是键,不是值
# 2、print(dic['']) #查询键,返回值
# 3、print(dic.get(''))  #如果没有查询到的话就会返回None
# 4、print(dic.setdefault(''))

#例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dic = {'广东':'广州','山东':'济南','海南':'三亚'}
# for i in dic:
#     print(i) #for循环默认是获取字典中的键
# 广东
# 山东
# 海南

print(dic['广东'])   #查看1,如果没有这个键的时候查询就会报错
# print(dic['湖北'])  #报错,NameError: name '湖北' is not defined

print(dic.get('广东','这个是没有的'))  #查看2,没有返回None,可以指定返回内容
#广州

print(dic.get('广西')) #None,因为没有这个key
print(dic.setdefault('广东'))  #如果没有的话也是返回None

#2.5.字典的其他操作(特有)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#keys  #获取到字典中的每一个键
#value  #获取到字典中的值
#itmes   #获取到字典中的键值对数据

#例子:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dic = {"id":123,"name":"cw","age":22,"ok":"大佬"}
print(dic.keys())  #(高仿列表)

for i in dic.keys():
    print(i)
#获取到键:id,name,age,ok

for i in dic:
    print(i)   #以上的几种方法都是获取到字典中的每一个键
#获取到id,name,age,ok

print(dic.values())
for i in dic.values():  #获取到字典中的每一个值
    print(i)
#获取到值:123,cw,22,大佬

for i in dic.items():  #获取到键值对
    print(i)
# ('id', 123)
# ('name', 'cw')
# ('age', 22)
# ('ok', '大佬')

3.字典的嵌套

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
嵌套就是一层套着一层,字典套着字典

#演练:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#写字典嵌套来查找
dic1 = {
           "name": "张世豪",
           "age": 18,
           "wife": {
                 "name": '大哥成',
                 "age": 28 },
           "children": ['第⼀个毛孩子', '第⼆个毛孩子'],
           "desc": '峰哥不不会告我吧. 没关系. 我想上头条的'
              }

#通过key取查找,使用get
#1.查找大哥成
#思路:首先可以看到大哥成是作为wife键的值,所以可以先找wife键,拿到值,再接着获取键name,打印出它的value值
print(dic1.get("wife")) #{'name': '大哥成', 'age': 28}
print(dic1.get("wife").get("name")) #大哥成

#2.查看28
#思路:和上面一样,通过找出键获取到值
print(dic1.get("wife").get("age")) #28

#3.查找第一个毛孩子
#思路:同样是通过键找出值,然后通过索引进行获取
print(dic1.get("children")[0]) #第⼀个毛孩子

#嵌套练习

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dic1 = {
    'name':['guo',2,3,5],
    'job':'teacher',
    'dianshi':{'haijun':['python1','python2',100]}
}
#要求
# 1,将name对应的列表追加⼀个元素’ke’。
# 2,将name对应的列表中的guo首字母大写。
# 3,dianshi对应的字典加一个键值对’蒋小鱼’,’niubi’。
# 4,将dianshi对应的字典中的haijun对应的列表中的python2删除
#
s1 = (dic1.get('name'))
s1.append('ke')
print(s1) #['guo', 2, 3, 5, 'ke']

print(dic1.get('name')[0].capitalize()) #Guo

dic1['蒋小鱼'] = 'niubi'
print(dic1) #{'name': ['guo', 2, 3, 5], 'job': 'teacher', 'dianshi': {'huijun': ['python1', 'python2', 100]}, '蒋小鱼': 'niubi'}

dic2 = (dic1.get('dianshi').get('haijun').pop(1))
print(dic2) #python2
print(dic1)
#{'name': ['guo', 2, 3, 5], 'job': 'teacher', 'dianshi': {'haijun': ['python1', 100]}}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-03-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Python基本数据类型(三)
集合(set)是一个无序不重复元素的序列,基本功能是进行成员关系测试和删除重复元素,可以使用大括号({})或者 set()函数创建集合;
py3study
2020/01/08
1.1K0
python入门到放弃(八)-基本数据类型之set集合
#注意点1:集合中的元素是不重复的,且无序的,所以打印出来的元素位置可能会和定义的位置不一样
老油条IT记
2020/03/20
4400
【六】Python基础之数据结构:字典
Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,字典是另 一种可变容器模型,且可存储任意类型对象。具有极快的查找速度。
菲宇
2019/06/13
5110
Python之运算符以及基本数据类型的object
一、运算符 1、算术运算符 %   求余运算 **    幂-返回x的y次幂 //    取整数-返回商的整数部分,例:9//2输出结果是4 2、比较运算符 ==  等于 !=  不等于 <>  不等于 >  大于  <  小于   >=  大于等于 <=  小于等于 3、赋值运算 =  简单的赋值 +=  加法赋值运算,c += a等效于c = c + a -=  减法赋值运算 *=  乘法赋值运算 /=  除法赋值运算 %=  取模赋值运算 **=  幂赋值运算符 //=  取整除赋值运算符 4、in
用户1173509
2018/01/17
2.6K0
Python之运算符以及基本数据类型的object
python入门到放弃(五)-基本数据类型之list列表
1.概述 列表是python的基本数据类型之一,是一个可变的数据类型,用[]方括号表示,每一项元素使用逗号隔开,可以装大量的数据 #先来看看list列表的源码写了什么,方法:按ctrl+鼠标左键点list class list(object): """ list() -> new empty list list(iterable) -> new list initialized from iterable's items """ def append(self, p
老油条IT记
2020/03/20
5580
python入门到放弃(六)-基本数据类型之tuple元组
#概述 元组俗称不可变的列表,又称只读列表,是python的基本数据类型之一, 用()小括号表示,里面使用,逗号隔开 元组里面可以放任何的数据类型的数据,查询可以,循环可以,但是就是不能修改 #先来看看tuple元组的源码写了什么,方法:按ctrl+鼠标左键点tuple lass tuple(object): """ tuple() -> empty tuple tuple(iterable) -> tuple initialized from iterable's items
老油条IT记
2020/03/20
5250
Python基本数据类型(四)
Queue是python标准库中的线程安全的队列FIFO(先进先出)实现,提供了一个适用于多线程编程的先进先出的数据结构,即队列,用来在生产者和消费者线程之间的信息传递;
py3study
2020/01/15
6080
python-基础案例
范例一: 练习:元素分类 有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。 即: {'k1': 大于66 , 'k2': 小于66} #!/usr/bin/env pyton #coding:utf-8 a = [11,22,33,44,55,66,77,88,99,90] dic = {} for item in a: if item > 66: if 'k2' in dic.
洗尽了浮华
2018/01/22
1.5K0
python-基础案例
Python学习记录day3
2)list(),原理是调用__init__,内部执行for循环将元素添加到list中。
py3study
2020/01/03
3900
python-字典方法(dist)知识整
#!/usr/bin/env python # -*- coding:utf-8 -*- # __author__:anxu.qi # Date:2018/11/30 info = { 'stu1101': "TengLan Wu", 'stu1102': "LongZe Luola", "stu1103": "XiaoZe Maliya", } ####################################### 多级字典的嵌套 ####################
py3study
2020/01/20
1.8K0
数据类型(一)、collections模块
除python提供的内置数据类型(int、float、str、list、tuple、dict)外,collections模块还提供了其他数据类型,使用如下功能需先导入collections模块(import collections):
狼啸风云
2023/10/07
3150
数据类型(一)、collections模块
Python数据类型之字符串
字符串是由字符组成的序列,是一个有序的字符的集合,用于存储和表示基本的文本信息,'' 或 " " 或 ''' '''中间包含的内容称之为字符串。
后场技术
2020/09/03
6170
Python数据类型之字符串
我要学python之python语法及规
单行注释: # 多行注释: """ 写入注释内容 """ ''' 写入多行注释内容 '''
py3study
2020/01/14
3750
【四】Python基础之数据结构:列表
序列是Python中最基本的数据结构。序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推。Python有6个序列的内置类型,但最常见的是列表和元组。序列都可以进行的操作包括索引,切片,加,乘,检查成员。
菲宇
2019/06/12
3620
Python基础之函数等等
需要删除:? 需要新建:? 需要更新:?  注意:无需考虑内部元素是否改变,只要原来存在,新汇报也存在,就是需要更新
程序员同行者
2018/07/24
6480
Python基础之函数等等
Python基础数据类型之字典
 基础数据类型之字典 ps:数据类型划分:可变数据类型和不可变数据类型。 不可变数据类型:元组(tupe)、布尔值(bool)、整数型(int)、字符串(str)。不可变数据类型也称为可哈希。 可变数据类型:列表(list)、字典(dict)、集合(set)。可变数据类型也称为不可哈希。 字典   字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据。python对key进行哈希函数运算,根据计算的结果决定value的存储地址,所以字典是无序存储的,且key必须是可哈希的。可哈
新人小试
2018/04/12
8540
一、python学习笔记-基本数据类型-字典
""" 1、字典是另一种可变容器模型,且可存储任意类型对象。 2、字典的每个键值 key=>value 对用冒号 : 分割,每个键值对之间用逗号 , 分割,整个字典包括在花括号 {} 中 3、字典是无序的(不能通过索引取值) 4、字典的键是惟一的 """ 创建和删除 # 创建字典 """ 1、字典的键(key)是唯一的,必须是不可变类型的(字符串,整形,元组),不能是可变类型的(列表,字典)。详见可变和不可变类型 """ dic = {1: 1, 2: 2, 3: 3, 4: 'a'} # 打印内容 pr
堕落飞鸟
2022/01/12
3290
【五】Python基础之数据结构:元组
与字符串一样,元组之间可以使用 + 号和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。
菲宇
2019/06/13
4030
Python学习之time模块(十)
time模块提供了各种与时间有关的功能,想了解该模块的详细信息的可以参考官方的文档:
无涯WuYa
2018/10/25
5960
35个高级Python知识点总结
众所周知,Java中强调“一切皆对象”,但是Python中的面向对象比Java更加彻底,因为Python中的类(class)也是对象,函数(function)也是对象,而且Python的代码和模块也都是对象。
py3study
2020/01/08
2.4K0
相关推荐
Python基本数据类型(三)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验