百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

python的字典及相关操作(python 的字典)

off999 2024-09-27 13:59 36 浏览 0 评论

一、什么是字典

字典是Python中最强大的数据类型之一,也是Python语言中唯一的映射类型。映射类型对象里哈希值(键,key)和指向的对象(值,value)是一对多的的关系,通常被认为是可变的哈希表,字典对象是可变的,它是一个容器类型,能存储任意个数的Python对象,其中也可包括其他容器类型。

字典类型与序列类型的区别:
1.存取和访问数据的方式不同。
2.序列类型只用数字类型的键(从序列的开始按数值顺序索引);
3.映射类型可以用其他对象类型作键(如:数字、字符串、元组,一般用字符串作键),和序列类型的键不同,映射类型的键直
4.接或间接地和存储数据值相关联。
5.映射类型中的数据是无序排列的,这和序列类型是不一样的,序列类型是以数值序排列的。
6.映射类型用键直接“映射”到值。

总之,Python中字典是一系列"键-值"对,每个键都与一个值关联,可以使用键来访问与之相关联的值。与键相关联的值可以是数字、字符串、列表乃至字典。事实上,可将任何Python对象用作字典中的值。

一个简单字典的示例:

student_A ={'name':'Allen','age':'14','grade':'8'} # 定义一个字典
print(student_A['name'])
print(student_A['age'])
print(student_A['grade'])

new_names = student_A['name']
new_ages = student_A ['age']
new_grades= student_A ['grade']
print("The student_A's name is " + new_names.title()+ ",and she is "+str(new_ages) +" years old,and Grade "+str(new_grades))
其中,student_A={'name':'Allen','age':'14','grade':'8'}  定义了一个名为student_A的字典,该字典中有三个关键字'name','age'和'grade',对应的值分别为'Allen','14'和'8'
student_A['name'] 表示引用的是student_A['name']的值,即Allen,也就是语句:new_names = student_A['name'] 和new_names='Allen'是一样的。

一、创建一个字典
1)如上述代码,直接定义一个字典,student_A ={'name':'Allen','age':'14','grade':'8'},列出各关键字和对应的值;
2)先使用一对花括号定义一个字典,再分行添加各个分键值对:
student_B={}
student_B['name']='Jack'
student_B['age']=13
student_B['grade']=7

二、在原有字典上添加“键-值”对:由于字典是可变的,能存储任意个数对象,因此可随意添加

student_A['address'] ="Hubei" #增加了一个地址健值对,由原来的3个变成4个
student_A['PhoneNumber'] ="18012345678"#增加了一个电话健值对,字典student_A里由4个变成5个
print(student_A)  #键 — 值对的排列顺序与添加顺序不同。Python不关心键-值对的添加顺序,而只关心键和值之间的关联关系

即在student_A字典原有3个关键字的基础上,增加了两个关键字address和PhoneNumber。

上述代码运行结果:

三、修改字典中的值:要修改字典中的值,可依次指定字典名、用方括号括起的键以及与该键相关联的新值。

student_B['age']=14  #修改student_B的age值为14
print(student_B)
print("\n")

四、删除键-值对:对于字典中不再需要的信息,可使用 del 语句将相应的键-值对彻底删除。使用 del 语句时,必须指定字典名和要删除的键。

del student_A['address']
print(student_A)

五、由类似对象组成的字典:字典存储的是一个对象(学生A或B)的多种信息,但也可以使用字典来存储众多对象的同一种信息

favor_languages = {'jack': 'python','sarah': 'c','lucy': 'ruby','phil': 'python'}
print(favor_languages['lucy'])

六、遍历字典
一个Python字典可能只包含几个键-值对,也可能包含数百万个键-值对。鉴于字典可能包含大量的数据,Python支持对字典遍历。字典可用于以各种方式存储信息,因此有多种遍历字典的方式:可遍历字典的所有键-值对、键或值。

for key,value in student_A.items():# 注意,student_A后增加了.items() 用于读取字典中的每一项
    print("\nKey: " + key)    #打印出关键字
    print("Value: " + value)  #打印出关键字的值
    
for name, language in favor_languages.items():     #遍历所有的键值对:用于遍历字典的for循环,可声明两个变量,用于存储键-值对中的键和值
    print(name.title() + "'s favorite language is " +language.title() + ".") #遍历字典中的每个键-值对,并将键存储在变量name中,而将值存储在变量language 中 

for name in favor_languages.keys():#遍历字典中的所有键,在不需要使用字典中的值时,方法 keys() ,注意后面增加的keys()
    print(name.title())  
print("\n")

my_friends = ['jack', 'sarah']
for name in favor_languages.keys():
    print(name.title())
        
    if name in my_friends: 
        print(" Hi " + name.title() +", I see your favorite language is " +favor_languages[name].title() + "!")

具体运行结果:

按顺序遍历字典中的所有键:字典记录键和值之间的关联关系,但获取字典的元素的顺序是不可预测的,要以特定的顺序返回元素,可对返回的键进行排序可使用函数 sorted() 来进行排序。

favor_languages= {'jack': 'python','polo': 'java','lucy': 'ruby','Albet': 'java'}
#使用函数 sorted() 来获得按特定顺序排列的键列表
for name in sorted(favor_languages.keys()): #对关键字进行排序
    print(name.title() + ", thank you !")
print("\n")     
#遍历字典中的所有值:如果主要获取的是字典包含的值,可使用方法 values()
for language in favor_languages.values():
    print(language.title())
print("\n")    
#使用集合(set)消除重复项  
for language in set(favor_languages.values()):
    print(language.title())  

运行结果如下:

文章来自https://www.cnblogs.com/codingchen/p/16138273.html

相关推荐

Linux 网络协议栈_linux网络协议栈

前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...

揭秘 BPF map 前生今世_bpfdm

1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...

教你简单 提取fmpeg 视频,音频,字幕 方法

ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...

Linux内核原理到代码详解《内核视频教程》

Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...

Linux C Socket UDP编程详解及实例分享

1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...

libevent源码分析之bufferevent使用详解

libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...

一次解决Linux内核内存泄漏实战全过程

什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...

彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏

作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...

linux网络编程常见API详解_linux网络编程视频教程

Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...

Linux下C++访问web—使用libcurl库调用http接口发送解析json数据

一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...

平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道

在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...

谈谈分布式文件系统下的本地缓存_什么是分布式文件存储

在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...

进程间通信之信号量semaphore--linux内核剖析

什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...

Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门

一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...

30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南

30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...

取消回复欢迎 发表评论: