字典!在Python中字典是另一种可变容器模型,可以存储任意类型的对象。是Python存储数据类型的最高级(maybe)。

  特点:1. 字典的存储方式和其他类型数据略有不同,是通过键(key)和值(value)的方式进行存储的,其特点很像平时去查找字典,键类似于字典的目录,值是想要查找的内容。

     2. 字典属于哈希表的一种应用。

       3. 字典是通过{ }来定义、存储、查找数据的。

     4. 字典元素的访问是通过键[" 键名 "]来访问元素的。

     5. 特别说明一下在字典的增删改查的操作中,记住这个公式:一个item = key + values,一个项目 = 一个键 + 值,后面对函数的用途就一目了然了。

1.   字典的简单应用

1.1   创建一个字典

  语法:dict = {key1:value1, key2:value2, keyn:valuen},字典的每一个键值(key = value)是一一对应的,且用冒号进行分割。

  字典包括{ }内键必须是唯一的,但职责可不比,因此字典是没有顺序的。字典很像一种数据库或者成绩单花名册。

 # 创建一个字典 #
# 创建一个空字典
dict0 = {}
print(dict0)
# 输出结果:{}
dict1 = {"Name": "Zara", }
print(dict1)
# 输出结果:{'Name': 'Zara'}
dict2 = {"Name": "Zara", "Age": 7, "Class": "First"}
print(dict2)
# 输出结果:{'Name': 'Zara', 'Age': 7, 'Class': 'First'}

1.2  字典的访问、修改和删除

  这里特别说明一下pop函数popitem函数,因为字典没有顺序这么一说,所以pop(keyname)也就类似于找到序号了;另外popitem函数,因为字典没有append这么一说,所以popitem()方法随机返回并删除字典的一对键和值(一般删除末尾对)。如果字典已经为空,调用了此方法,就会报keyerror异常。

 # 字典的访问和修改和删除 #(与列表、元组大同小异)
# 字典的访问[]
dict = {"Name": "Zara", "Age": 7, "Class": "First"}
print(dict["Name"]) # 通过键值访问
print(dict["Age"]) # 通过键值访问
# 输出结果:
# Zara
# # 字典的修改
# 通过键来修改
dict1 = {"Name": "Zara", "Age": 7, "Class": "First"}
dict1["Age"] = 8 # 通过键值修改内容
dict1["School"] = "Qingdao University" # 添加键值增加内容
print(dict1)
# 输出结果:
# {'Name': 'Zara', 'Age': 8, 'Class': 'First', 'School': 'Qingdao University'} # 字典的删除 del函数、clear函数、pop函数、popitem函数
dict3 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
del dict3["Name"] # 清除字典中的某个键值
print(dict3) # 键的删除其值也不复存在
# 输出结果:{'Age': 7, 'Class': 'First'} dict3.clear() # 清除字典中所有内容
print(dict3)
# 输出内容:{} dict3 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict3.pop("Name") # 删除给定key所对应的值
print(dict3)
# 输出结果:{'Age': 7, 'Class': 'First'} dict3 = {'Name': 'Zara', 'Age': 7, 'Class': 'First', "Married": "None"}
dict3.popitem()
print(dict3) # 随机返回并删除字典中对应的键和值
# 输出结果:{'Name': 'Zara', 'Age': 7, 'Class': 'First'}

2.   字典的常用内建函数的应用

  函:dict.copy()

    语:字典的拷贝

      用:属于深拷贝

 # dict.copy()
# 作用:字典的拷贝
dict4 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict5 = dict4.copy()
print(dict4, dict5)
# 输出结果: {'Name': 'Zara', 'Age': 7, 'Class': 'First'} {'Name': 'Zara', 'Age': 7, 'Class': 'First'}

   函:dict.fromkey()

    语:dict.fromkey(["key1", "key2", "keyn"])

      用:创建一个新字典,序列seq中元素作为字典的键,value中所有的值都初始化

 # dict.fromkeys
# 作用:创建一个新字典,一序列seq中元素做字典的键,val为字典所对应的初始化
dict6 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict7 = dict6.fromkeys(["Name", "Age", "Class"]) # 创建一个新字典,键值引用原先的那几个,且值都为None
print(dict7)
# 输出结果:{'Name': None, 'Age': None, 'Class': None}

   函:dict.get

    语:dict.get("key")

      用:获取某一个键的值,每次只能差一个,若没有次键值返回为None

 # dict.get
# 作用:获取某一个键的值,每次只能查一个,若没有此键值返回为None
dict8 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict9 = dict8.get("school")
dict10 = dict8.get("Class")
print(dict9, "来自于: ", dict8)
print(dict10, "来自于: ", dict8)
# 输出结果:
# None 来自于: {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
# First 来自于: {'Name': 'Zara', 'Age': 7, 'Class': 'First'}

   函:dict.setdefault

    语:dict.setdefault("key")

      用:与dict.get的效果一样,如果键不存于字典中,将会添加键并将值设为默认的None

 # dict.setdefault与get效果一样,如果键不存在于字典中,将会添加键并将值设置为default默认None
# 作用:获取某一个键的值,每次只能查一个
dict8 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict9 = dict8.setdefault("School")
print(dict9, dict8) # 将原先的赋值为None,重新提添加了一个键,值默认为None
# 输出结果:None {'Name': 'Zara', 'Age': 7, 'Class': 'First', 'School': None}

  函:dict.item

    语:dict.item()

      用:对整个字典进行遍历

 # dict.items()
# 作用:以列表返回可遍历的(键、值)
dict10 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict11 = dict10.items()
print(dict11) # 显示字典中所有元素的全貌
print(type(dict10))
print(type(dict11)) # 我们观察到这个遍历函数返回的是一个dict_items类型,可用list函数把找到的东西强制转换成列表形式。
# 输出结果:
# dict_items([('Name', 'Zara'), ('Age', 7), ('Class', 'First')])
# <class 'dict'>
# <class 'dict_items'>

   函:dict.key、dict.values

    语:dict.key()、dict.values()

      用:遍历整个字典中的键和值

 # dict.key()、dict.values()
# 作用:显示字典中所有的键值、显示字典中所有的值
dict11 = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict12 = dict11.keys()
print(list(dict12), dict11.values()) # 这里特别说明一下,可以用list函数把找到的东西强制转换成列表形式。
# 输出结果:['Name', 'Age', 'Class'] dict_values(['Zara', 7, 'First'])

   函:dict.update

    语:dict1.update(dict2)

      用:把dict2的字典更新到dict1里面,dict1的内容顺延添加到dict1的字典中。

 # dict.update()
# 作用:将某个字典中的值,后续顺延更新到某个字典中
dict13 = {'Name': 'Zara', 'Age': 7}
dict14 = {'Sex': 'female' }
dict14.update(dict13)
print(dict14)
# 输出结果:{'Sex': 'female', 'Name': 'Zara', 'Age': 7}

3.   字典常用的技巧

3.1   字典的遍历

 # 字典的遍历
dict15 = {"name": "aliex", "age": 18}
for i, v in enumerate(dict15):
print(i, v)
# 这里看枚举函数就不能使用了。
# 输出结果:
# 0 name
# 1 age dict15 = {"name": "aliex", "age": 18}
for i in dict15:
print(i, dict15[i]) # 首先找到i的键,然后通过dict[键]的方式再把值列出来
# 输出结果:
# name aliex
# age 18 for items in dict15.items():
print(items)
print(type(items))
# 这样遍历的方式,是把内容全部以元组方式进行输出
# 输出结果:
# ('name', 'aliex')
# ('age', 18)
# <class 'tuple'> for key,values in dict15.items():
print(key,values)
# 通过分开写的形式,可以遍历出具体的数据
# 输出结果:
# name aliex
# age 18

Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之字典类型(dict)的更多相关文章

  1. Python笔记_第一篇_面向过程_第一部分_2.内存详解

    Python的很多教材中并没有讲内存方面的知识,但是内存的知识非常重要,对于计算机工作原理和方便理解编程语言是非常重要的,尤其是小白,因此需要把这一方面加上,能够更加深入的理解编程语言.这里引用了C语 ...

  2. Python笔记_第一篇_面向过程_第一部分_1.Python环境的设置(含虚拟机)

    *Python环境的设置 Python的环境设置也就是所需工作平台的软件搭建.常用的搭建平台IOS系统+Linux系统和Windows+Linux系统的搭建.这里主要说明的是Windows+Linux ...

  3. Python笔记_第一篇_面向过程_第一部分_6.条件控制语句(if)

    Python正如其他语言一样存在两种常用的逻辑判断体(也叫结构化程序设计).所谓逻辑判断体是通过你想要完成的编程思路,通过在逻辑判断体中的相互判断和作用得到你想要的结果.逻辑判断体也叫控制语句,Pyt ...

  4. Python笔记_第二篇_面向过程_第二部分_2.路径、栈和队列、内存修改

    这一部分分三个主题进行讲解,主要为后面的模块.包.第三方库的概念补充一些相关的内容. 1. 路径(Path): 相对路径和绝对路径. 举例1:我们先导入一个os库(模块)来观察一下路径 import ...

  5. 四、java基础-面向过程_对象_类中可出现的因素

    1.面向过程和面向对象区别: 1)面向过程:开发一个应用程序.一个项目,必须先了解整个过程,了解各个步骤.模块间的因果关系,使的面向过程方式去开发程序时,代码和代码之间的关联程度是非常强.所以其中任何 ...

  6. python自动化开发-[第五天]-面向过程、模块、包

    今日概要: 1.内置模块 2.协程函数 3.递归 4.面向过程编程与函数编程 5.模块 6.包 7.re正则 一.内置模块 1.匿名函数lambda 定义:匿名函数通常是创建了可以被调用的函数,它返回 ...

  7. python第四周迭代器生成器序列化面向过程递归

      第一节装饰器复习和知识储备------------ 第一节装饰器复习和知识储备------------ def wrapper(*args,**kwargs): index(*args,**kwa ...

  8. [Python笔记]第八篇:模块

    本篇主要内容:python常用模块用法介绍 什么是模块 模块,用一大段代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性 ...

  9. [Python笔记]第三篇:深浅拷贝、函数

    本篇主要内容:深浅拷贝,自定义函数,三目运算,lambda表达式, 深浅拷贝 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址. import ...

随机推荐

  1. 【剑指Offer】面试题05.替换空格

    题目 请实现一个函数,把字符串 s 中的每个空格替换成"%20". 示例 1: 输入:s = "We are happy." 输出:"We%20are ...

  2. 深度理解js中var let const 区别

    首先要理解js中作用域的概念 作用域:指的是一个变量的作用范围 1.全局作用域 直接写在script中的js代码,在js中,万物皆对象,都在全局作用域,全局作用域在页面打开时创建,在全局作用域中有一个 ...

  3. 翻翻棋(找规律问题)(FZU Problem 2230)

    题目是这样的: FZU Problem 2230 象棋翻翻棋(暗棋)中双方在4*8的格子中交战,有时候最后会只剩下帅和将.根据暗棋的规则,棋子只能上下左右移动,且相同的级别下,主动移动到地方棋子方将吃 ...

  4. 吴裕雄--天生自然 JAVASCRIPT开发学习:作用域

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. redis(六)---- 简单延迟队列

    延迟队列的应用场景也很常见,例如:session的超时过期.自动取消未付款订单等等.redis中有一种数据结构叫做zset,即有序集合.元素类型为String类型,且元素具有唯一性不能重复,每个元素可 ...

  6. 图像算法五:【图像小波变换】多分辨率重构、Gabor滤波器、Haar小波

    原 https://blog.csdn.net/alwaystry/article/details/52756051 图像算法五:[图像小波变换]多分辨率重构.Gabor滤波器.Haar小波 2018 ...

  7. win10编译zlib

    zlib是一个数据压缩库,官网的解释很酷: A Massively Spiffy Yet Delicately Unobtrusive Compression Library(Also Free, N ...

  8. 牛逼了,用Python破解wifi密码

    Python真的是无所不能,原因就是因为Python有数目庞大的库,无数的现成的轮子,让你做很多很多应用都非常方便.wifi跟我们的生活息息相关,无处不在.今天从WiFi连接的原理,再结合代码为大家详 ...

  9. [mysql8 报错] 关闭ONLY_FULL_GROUP_BY

    bug原因: 对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中.简而言之,就是SELECT后面接的列必须 ...

  10. android stutio 添加依赖

    添加依赖有 3种方法: 1 :copy jar 包到libs目录 ,add to library 2: copy  aar 文件到libs  ,gradle 文件 android 节点添加  repo ...