FishC笔记—26 讲 字典:当索引不好用时2

本期内容详解:
1、dict()是一个工厂函数,调用后会生成该类型的实例
2、字典的一种内建方法:dict1.fromkeys(s[,v])
3、访问字典的方法:
1)dict1.keys()、dict1.value()、dict1.items()(返回每一项)
2)dict1.get(),对应键的值不存在的话返回一个None,这样程序就不会报错
3)key in dict1:查找的是键,而不是值
4)dict1.clear():清空字典,不建议使用直接赋空值的方法:dict1 = {}
例如:

    >>> a = {'A','B'}  
    >>> b = a  
    >>> a = {}  
    >>> b  
    {'B', 'A'}  
    >>> a  
    {}  

5)dict1.copy():浅拷贝
例如:

    >>> a = {1:'one',2:'two',3:'three'}  
    >>> b = a.copy()  
    >>> c = a  
    >>> c[4] = 'four'  
    >>> c  
    {1: 'one', 2: 'two', 3: 'three', 4: 'four'}  
    >>> a  
    {1: 'one', 2: 'two', 3: 'three', 4: 'four'}  
    >>> b  
    {1: 'one', 2: 'two', 3: 'three'}  

6)dict1.pop():给定键弹出相应值
7)dict1.popitem():给定键弹出相应项(包括键和值)
8)dict1.setdefault():找不到给定键对应的值话会自动在字典中创建一个基于该键的项(区别于dict1.get()的结果)
9)dict1.update():根据一个字典或映射关系去更新另一个字典
例如以下用法(结果类似于在字典中添加项或更新已存在键对应的值):

    >>> a  
    {1: 'one', 2: 'two', 3: 'three', 4: 'four'}  
    >>> d = {7:'seven'}  
    >>> a.update(d)  
    >>> a  
    {1: 'one', 2: 'two', 3: 'three', 4: 'four', 7: 'seven'}  

Python的字典是否支持一键(Key)多值(Value)?

答:不支持,对相同的键再次赋值会将上一次的值直接覆盖。

在字典中,如果试图为一个不存在的键(Key)赋值会怎样?

答:会自动创建对应的键(Key)并添加相应的值(Value)进去。

成员资格操作符(in和not in)可以检查一个元素是否存在序列中,当然也可以用来检查一个键(Key)是否存在字典中,那么请问哪种的检查效率更高些?为什么?

答:在字典中检查键(Key)是否存在比在序列中检查指定元素是否存在更高效。因为字典的原理是使用哈希算法存储,一步到位,不需要使用查找算法进行匹配,因此时间复杂度是O(1),效率非常高。

Python对键(Key)和值(Value)有没有类型限制?

答:Python对键的要求相对要严格一些,要求它们必须是可哈希(Hash)的对象,不能是可变类型(包括变量、列
表、字典本身等)。
但是Python对值是没有任何限制的,它们可以是任意的Python对象。
如果不清楚哈希原理以及字典的存放原理的童鞋,推荐阅读下小甲鱼帮你整理的这篇文章:你知道Python的字典
(Dict)是如何存储的吗?(http://bbs.fishc.com/thread-45016-1-1.html)

请目测下边代码执行后,字典dict1的内容是什么?

    >>> dict1.fromkeys((1, 2, 3), ('one', 'two', 'three'))   
    >>> dict1.fromkeys((1, 3), '数字')  

答:执行完成后,字典dict1的内容是:{1: ‘数字’, 3: ‘数字’}
这里要注意的是,fromkeys方法是直接创建一个新的字典,不要试图使用它来修改一个原有的字典,因为它会直接无情的用把整个字典给覆盖掉。

如果你需要将字典dict1 = {1: ‘one’, 2: ‘two’, 3: ‘three’}拷贝到dict2,你应该怎么做?

答:可以利用字典的copy()方法:dict2 = dict1.copy(),在其他语言转移到Python小伙伴们刚开始可能会习惯性的直接用赋值的方法(dict2 = dict1),这样子做在Python中只是将对象的引用拷贝过去而已(如笔记中提到的例子)。

尝试编写一个用户登录程序(这次尝试将功能封装成函数),程序实现如图:
FishC笔记—26 讲 字典:当索引不好用时2_第1张图片

    def Load():  
        dict1 = {'小甲鱼':'FishC'}  
        while 1:  
            key = input(''''' 
    |--- 新建用户:N/n ---| 
    |--- 登录帐号:E/e ---| 
    |--- 退出程序:Q/q ---| 
    |--- 请输入指令代码:''')  
            if key == 'N' or key == 'n':  
                temp_name = input('请输入用户名:')  
                while temp_name in dict1:  
                    temp_name = input('此用户名已经被使用,请重新输入:')  

                temp_password = input('请输入密码:')  
                dict1[temp_name] = temp_password  
                print('注册成功,赶紧试试登录吧^_^')  
                continue  

            elif key == 'E' or key == 'e':  
                temp_name = input('请输入用户名:')  
                while temp_name not in dict1:  
                    temp_name = input('您输入的用户名不存在,请重新输入:')  
                temp_password = input('请输入密码:')  
                while temp_password != dict1[temp_name]:  
                    temp_password = input('密码错误,请重新输入:')  
                print('欢迎进入系统,请点右上角的X结束程序!')  
                continue  

            elif key == 'Q' or key == 'q':  
                break  


    Load()  

你可能感兴趣的:(python)