百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python字典入门:掌握基础知识

liuian 2024-11-28 00:42 30 浏览

Python中的字典是无序的,key:value成对,key是唯一的且不可变的,value可以是任意类型。字典跟列表一样具有增删改查的方法。

1.创建字典

>>> d =  {} #创建一个空字典
>>> type(d)
<class 'dict'>
>>> d = {"a":1,"b":2,"c":3}
>>> d
{'a': 1, 'b': 2, 'c': 3}

2.访问字典里面的值

>>> d = {"a":1,"b":2,"c":3}
>>> d.keys() # 访问所有的键(key)
dict_keys(['a', 'b', 'c'])
>>> d.values() # 访问所有的值(value)
dict_values([1, 2, 3])
>>> >>> d['a'] #直接通过 键(key)访问
1
>>> for k,v in d.items(): # for循环遍历
  print("key={},value={}".format(k,d[k]))


  
key=a,value=1
key=b,value=2
key=c,value=3

3.修改字典里面的值

>>> d = {"a":1,"b":2,"c":3}
>>> d["a"] = -1 # 直接通过键来赋值
>>> d
{'a': -1, 'b': 2, 'c': 3}


4.删除字典的值

>>> d = {"a":1,"b":2,"c":3}
>>> del d["a"] # del 指定的键来删除
>>> d
{'b': 2, 'c': 3}
>>> d.clear()  # clear()直接清空整个字典
>>> d
{}
>>> >>> del d  # del 字典,直接在内存里面删除字典
>>> d
Traceback (most recent call last):
  File "<pyshell#52>", line 1, in <module>
    d
NameError: name 'd' is not defined
>>>


5.其它常用方法跟函数

1.clear()清空字典

>>> d = {"a":1,"b":2,"c":3}
>>> d.clear()
>>> d
{}


2.del 删除字典

>>> d = {"a":1,"b":2,"c":3}
>>> del d
>>> d
Traceback (most recent call last):
  File "<pyshell#58>", line 1, in <module>
    d
NameError: name 'd' is not defined
>>>

3.copy()复制字典

>>> d = {"a":1,"b":2,"c":3}
>>> d2 = d.copy()
>>> d2
{'a': 1, 'b': 2, 'c': 3}
>>>

4.get()通过键获取值

>>> d = {"a":1,"b":2,"c":3}
>>> d.get("a")
1

5.通过in 判断key是否在字典里面

>>> d = {"a":1,"b":2,"c":3}
>>> 'a' in d
True

6.items()返回key-value视图,可通过for来遍历

>>> d = {"a":1,"b":2,"c":3}
>>> d.items()
dict_items([('a', 1), ('b', 2), ('c', 3)])
>>>

7.keys()获取所有的键

>>> d = {"a":1,"b":2,"c":3}
>>> d.keys()
dict_keys(['a', 'b', 'c'])

8.values()获取所有的值

>>> d = {"a":1,"b":2,"c":3}
>>> d.values()
dict_values([1, 2, 3])
>>>

9.setdefault()按键键查询,值存在不存在,存在返回值,不存在在添加查询的键,值为None

>>> d = {"a":1,"b":2,"c":3}
>>> d.setdefault("a")
1
>>> d.setdefault("d")
>>> d
{'a': 1, 'b': 2, 'c': 3, 'd': None}
>>>

10.update()把一个把字典2添加到字典1中,如果有相同的key,字典2覆盖字典1的value

>>> d1 = {"a":1,"b":2,"c":3}
>>> d2 = {"d":4,"e":5}
>>> d1.update(d2)
>>> d1
{'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}
>>> d3 = {"a":4,"f":6}
>>> d1.update(d3)
>>> d1
{'a': 4, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6}
>>>

11.pop()删除指定key,返回删除的key对应的value

>>> d.pop("a")
1
>>> d
{'b': 2, 'c': 3}
>>>

12.popitem()删除最后一个key-value,并且返回

>>> d = {"a":1,"b":2,"c":3}
>>> d.popitem()
('c', 3)
>>> d
{'a': 1, 'b': 2}

13.fromkeys()用于创建一个新的字典,其中包含指定数量的元素,每个元素的键都是一个给定的值。

>>> d = dict.fromkeys(("a","b","c"),6)
>>> d
{'a': 6, 'b': 6, 'c': 6}
>>> 

相关推荐

10种常见的MySQL错误,你可中招?

【51CTO.com快译】如果未能对MySQL8进行恰当的配置,您非但可能遇到无法顺利访问、或调用MySQL的窘境,而且还可能给真实的应用生产环境带来巨大的影响。本文列举了十种MySQL...

MySQL主从如何保证数据一致性

MySQL主从(主备)搭建请点击基于Spring的数据库读写分离。MySQL主备基本原理假设主备切换前,我们的主库是节点A,节点B是节点A的备库,客户端的读写都是直接访问节点A,节点B只是将A的更新同...

MySQL低版本升级操作流程

(关注“数据库架构师”公众号,提升数据库技能,助力职业发展)0-升级背景MySQL5.5发布于2010年,至今已有十年历史,官方已经停止更新。2008年发布的MySQL5.1版本,在2018年...

MySQL数据库知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

Mysql 8.4数据库安装、新建用户和数据库、表单

1、下载MySQL数据库yuminstall-ywgetperlnet-toolslibtirpc#安装wget和perl、net-tools、libtirpcwgethtt...

mysql8.0新功能介绍

MySQL8.0新特性集锦一、默认字符集由latin1变为utf8mb4在8.0版本之前,默认字符集为latin1,utf8指向的是utf8mb3,8.0版本默认字符集为utf8mb4,utf8默...

全网最详细解决Windows下Mysql数据库安装后忘记初始root 密码方法

一、准备重置root的初始化密码Win+R键启动命令输入窗口;输入cmd打开命令执行窗口;##界面如下##输入命令:netstopmysqld#此操作会停止当前运行的...

互联网大厂面试:MySQL使用grant授权后必须flush privilege吗

从我上大学时,数据库概论老师就告诉我,MySQL使用grant对用户授权之后,一定记得要用flushprivilege命令刷新缓存,这样才能使赋权命令生效。毕业工作以后,在很多的技术文档上,仍然可以...

# mysql 8.0 版本无法使用 sqlyog 等图形界面 登录 的解决方法

30万以下的理想L6来了##mysql8.0版本无法使用sqlyog等图形界面登录的解决方法当我们在cmd下登录mysql时正常时,用sqlyog等图形界面连接数据库时却...

MySQL触发器介绍

前言:在学习MySQL的过程中,可能你了解过触发器的概念,不清楚各位是否有详细的去学习过触发器,最近看了几篇关于触发器的文档,分享下MySQL触发器相关知识。1.触发器简介触发器即trigg...

管理员常用的MySQL命令汇总(一)

以下是管理员常用的MySQL命令:以管理员身份连接到MySQL:mysql-uroot-p创建新的MySQL用户:CREATEUSER'username'@'...

Linux(CentOS) 在线安装MySQL8.0和其他版本,修改root密码

一:安装MySQL数据库1),下载并安装MySQL官方的YumRepositorymysql官方仓库地址:https://dev.mysql.com/downloads/repo/yum/选择自...

解决 MySQL 8.0 一直拒绝 root 登录问题

Accessdeniedforuser'root'@'localhost'(usingpassword:YES)这个错误在网上搜一下,能看到非常多的此类...

大模型MCP之MYSQL安装

前言学习大模型的时候需要一个mysql,原因还是在公司使用电脑的时候不允许按照Docker-Desktop,我的宿主机其实是MAC,我习惯上还是在centsos上面安装,就发现这件过去很简单的事情居然...

MySQL ERROR 1396

ERROR1396(HY000):OperationCREATEUSERfailedfor'usera'@'%'问题描述mysql>create...