zoukankan      html  css  js  c++  java
  • setdefault函数的用法及个人理解

    setdefault函数的用法及理解

    dict.setdefault(key, default=None)

    功能:
    如果键不存在于字典中,将会添加该键并将default的值设为该键的默认值,如果键存在于字典中,将读出该键原来对应的值,default的值不会覆盖原来已经存在的键的值。

    参数:
    key----要查找的键
    default-----查找的键不存在时用于设置的默认值

    使用方法示例:(以下使用方法是我理解setdefault函数的过程)
    方法一:给字典中不存在的键赋值为默认值None

    >>> ExsampleDict={"Exist":"Elle"}
    >>> Res=ExsampleDict.setdefault("NotExist",)
    >>> print ExsampleDict
    {'NotExist': None, 'Exist': 'Elle'}

    方法二:给字典中不存在的键赋值为默认值None

    >>> ExsampleDict={"Exist":"Elle"}
    >>> Res=ExsampleDict.setdefault("NotExist")
    >>> print ExsampleDict
    {'NotExist': None, 'Exist': 'Elle'}
    >>> 

    方法三:读出字典中存在的键对应的值

    >>> ExsampleDict={"Exist":"Elle"}
    >>> Res=ExsampleDict.setdefault("Exist","NotReplace")
    >>> print Res
    Elle
    >>> type(Res)
    <type 'str'>
    >>> print ExsampleDict["Exist"]
    Elle
    >>> 

    方法四:给字典中不存在的键赋值为"Replace"

    >>> ExsampleDict={"Exist":"Elle"}
    >>> Res=ExsampleDict.setdefault("NotExist","Replace")
    >>> print Res
    Replace
    >>> type(Res)
    <type 'str'>
    >>> print ExsampleDict
    {'NotExist': 'Replace', 'Exist': 'Elle'}
    >>> 

    方法五:给字典中不存在的键赋值为列表

    >>> ExsampleDict={"Exist":"Elle"}
    >>> Res=ExsampleDict.setdefault("NotExist",[])
    >>> print Res
    []
    >>> type(Res)
    <type 'list'>
    >>> Res=ExsampleDict.setdefault("NotExist",[]).append("Replace")
    >>> print ExsampleDict
    {'NotExist': ['Replace'], 'Exist': 'Elle'}
    >>> 

    方法六:给字典中不存在的键赋值为字典

    >>> ExsampleDict={"Exist":"Elle"}
    >>> ExsampleDict.setdefault("NotExist",{})
    {}
    >>> ExsampleDict={"Exist":"Elle"}
    >>> Res=ExsampleDict.setdefault("NotExist",{})
    >>> print Res
    {}
    >>> type(Res)
    <type 'dict'>
    >>> Res=ExsampleDict.setdefault("NotExist",{})["Insert"]="InsertValue"
    >>> print ExsampleDict
    {'NotExist': {'Insert': 'InsertValue'}, 'Exist': 'Elle'}
    >>> 
  • 相关阅读:
    SQLAlchemy(2) -- SQLAlchemy的安装
    SQLAlchemy(1) -- Python的SQLAlchemy和ORM
    http-proxy-middleware及express实现反向代理
    Vue项目中的http请求统一管理
    vue.js中如何使用scss
    Vue 相关开源项目库汇总
    Vue UI组件库
    route按需加载的3种方式:vue异步组件、es提案的import()、webpack的require.ensure()
    Npoi Web 项目中(XSSFWorkbook) 导出出现无法访问已关闭的流
    vuejs 和 element 搭建的一个后台管理界面
  • 原文地址:https://www.cnblogs.com/elleblog/p/7533413.html
Copyright © 2011-2022 走看看