- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python 如何读取字典的所有键-值对由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
如果字典中存储了一些值,我想要取出来该怎么操作呢?
取出字典中所有的键-值对时,可以使用items()返回一个键值对列表,并配合for循环进行遍历 。
1
2
3
4
|
#创建一个存储一个学生的信息,通过遍历可以取出所有信息
student
=
{
'name'
:
'xiaoming'
,
'age'
:
11
,
'school'
:
'tsinghua'
}
for
key,value
in
student.items():
print
(key
+
':'
+
str
(value))
|
输出:
age:11 。
name:xiaoming 。
school:tsinghua 。
注意:
遍历出的返回值输出和存储的顺序不一样,输出顺序每次都会变化 。
在for循环中key和value两个变量需要使用逗号‘,'隔开 。
可以使用keys()方法取出字典中的键,不取对应的值 。
1
2
3
4
|
#创建一个人和对应喜欢水果的字典
people
=
{
'lifei'
:
'apple'
,
'fanming'
:
'peach'
,
'gaolan'
:
'banana'
,
'hanmeimie'
:
'peach'
}
for
name
in
people.keys():
print
(name)
|
输出:(顺序是随机的) 。
hanmeimie 。
gaolan 。
fanming 。
lifei 。
注意:keys()方法返回的是列表,要用列表的思维考虑问题 。
keys()返回的值顺序是不确定的,如果想按序排列,可以使用sorted()进行排序 。
1
2
3
4
|
#创建一个人和对应喜欢水果的字典
people
=
{
'lifei'
:
'apple'
,
'fanming'
:
'peach'
,
'gaolan'
:
'banana'
,
'hanmeimie'
:
'peach'
}
for
name
in
sorted
(people.keys()):
print
(name)
|
输出:
fanming 。
gaolan 。
hanmeimie 。
lifei 。
可以使用values()取出字典中的值 。
1
2
3
4
|
#创建一个人和对应喜欢水果的字典
people
=
{
'lifei'
:
'apple'
,
'fanming'
:
'peach'
,
'gaolan'
:
'banana'
,
'hanmeimie'
:
'peach'
}
for
fruit
in
people.values():
print
(fruit)
|
输出:
peach 。
banana 。
peach 。
apple 。
注意,有没有看到上边输出的结果中有重复值,如果我想去除重复值怎么办呢,可以使用集合set() 去除重复值 。
1
2
3
4
|
#创建一个人和对应喜欢水果的字典
people
=
{
'lifei'
:
'apple'
,
'fanming'
:
'peach'
,
'gaolan'
:
'banana'
,
'hanmeimie'
:
'peach'
}
for
fruit
in
set
(people.values()):
print
(fruit)
|
输出:
apple 。
peach 。
banana 。
创建一个人员名单,有些人在水果字典中(承接上边的喜欢水果字典),有些人不在其中,对于已明确喜欢水果的,询问是否还需要其它的水果,对于未明确喜欢水果的,邀请他说出他喜欢的一种水果.
1
2
3
4
5
6
7
8
|
#创建一个人和对应喜欢水果的字典
people_fruit
=
{
'lifei'
:
'apple'
,
'fanming'
:
'peach'
,
'gaolan'
:
'banana'
,
'hanmeimei'
:
'peach'
}
people
=
[
'lilei'
,
'caiming'
,
'hanmeimei'
,
'gaolan'
]
for
name
in
people:
if
name
in
people_fruit.keys():
print
(
'您还需要其他的水果吗?'
)
elif
name
not
in
people_fruit.keys():
print
(
'你能告诉我您喜欢的一种水果吗?'
)
|
输出:
你能告诉我您喜欢的一种水果吗?
你能告诉我您喜欢的一种水果吗?
您还需要其他的水果吗?
您还需要其他的水果吗?
一上午好多事,费了好大劲才学完这一节啊 。
1、首先遍历字典所有的键-值对可以使用items() 。
2、只遍历键时可以使用key(),还可以使用sorted()进行排序 。
3、只遍历值时,可以使用values(),还可以使用set()去除值中重复的值 。
补充:python 取出字典的键或者值/如何删除一个字典的键值对/如何遍历字典 。
先定义一个字典并直接进行初始化赋值 。
1
|
my_dict
=
dict
(name
=
"lowman"
, age
=
45
, money
=
998
, hourse
=
None
)
|
key_list = my_dict.keys() 返回的是列表 。
1
2
3
|
my_dict
=
dict
(name
=
"lowman"
, age
=
45
, money
=
998
, hourse
=
None
)
key_list
=
my_dict.keys()
print
(
list
(key_list))
|
输出:
['hourse', 'name', 'age', 'money'] 。
取出字典所有的键,这里其实还有一个方法, 就是使用内置函数set(), 将其转换为集合数据结构. 集合,其实可以理解为只有键的字典
1
2
3
|
item
=
{
"name"
:
"lowman"
,
"age"
:
27
}
data
=
set
(item)
print
(data)
|
输出
{'age', 'name'} 。
注意,这样输出的是集合类型 。
value_list = my_dict.values() 返回的是列表 。
1
2
3
|
my_dict
=
dict
(name
=
"lowman"
, age
=
45
, money
=
998
, hourse
=
None
)
value_list
=
my_dict.values()
print
(
list
(value_list))
|
输出:
[None, 45, 'lowman', 998] 。
注意:在python2环境中这两个方法返回的是列表,但是在python3环境下返回的却是迭代器,如果希望通过下标直接取到需要的元素,可以通过list()方法将其先转化为列表,再进行取值. 。
value = my_dict["key"] 这样取值的话如果没有这个键就会抛出异常 。
这样取值的话如果没有这个键就返回None:value = my_dict.get("key") 。
也可以自定义一个默认值进行返回:value = my_dict.get("key", 默认值) 。
1
2
|
for
item
in
my_dict:
print
(item)
|
输出:
name 。
hourse 。
money 。
age 。
取出的是该字典的键 。
1
2
3
4
|
for
key, value
in
my_dict.items():
print
(key,value)
for
item
in
my_dict.items():
print
(item)
# 这样取值的话,返回的就是一个元组,里面包含两个元素,第一个是键,第二个为值
|
输出:
hourse None 。
money 998 。
age 45 。
name lowman 。
('hourse', None) 。
('money', 998) 。
('age', 45) 。
('name', 'lowman') 。
1
2
|
my_dict
=
{
"name"
:
"lowman"
,
"age"
:
12
}
del
my_dict[
"name"
]
|
这样就把整个键值对给删除掉了 。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我.
原文链接:https://blog.csdn.net/a411178010/article/details/78548168 。
最后此篇关于Python 如何读取字典的所有键-值对的文章就讲到这里了,如果你想了解更多关于Python 如何读取字典的所有键-值对的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我遇到以下问题。我想读取一个包含数百万行和数百列的大型 csv。我想向下转换列的数据类型。我的方法是读取 csv,然后使用 pd.to_numeric() 对其进行向下转换。我不知道列数及其类型。在读
目前,我从 SQL server (2008) 数据库获取数据。 cyurrent的方法是使用DataTable,然后将其传递并使用。 if (parameters != null)
我有以下问题。我有一个巨大的 csv 文件,想用多处理加载它。对于一个包含 500000 行和 130 列不同数据类型的示例文件,Pandas 需要 19 秒。我试过 dask 因为我想多处理阅读。但
是否有关于用于序列化各种 MFC 数据结构的二进制格式的明确文档?我已经能够在十六进制编辑器中查看我自己的一些类,并使用 Java 的 ByteBuffer 类读取它们(使用自动字节顺序转换等)。 但
我正在使用 Selenium 进行测试,我们用 HTML 文件编写测试用例,并用它们制作测试套件,我们的要求是编写足够健壮的测试用例,以根据测试环境改变自身。 为此,我不希望在 HTML 脚本本身中包
我需要一个 JavaScript 代码来读取存储为 .txt 文件的字典(或者也可以保存为任何其他类型的文件。它也可以在线获得)并将其内容存储在一个变量中。我不能找到一种让 JavaScript 像
我正在尝试遍历包含 SSH 登录和其他日志的日志文本文件。 程序正在返回 SSH 登录的总数。 我的解决方案确实有效,但似乎有点慢(在 200mo 文件上大约需要 3.5 秒)。我想知道是否有任何方法
我正在将大量数据从一个电子表格复制到工作簿中的其他 160 个电子表格。目前,Excel (2013) 遇到错误,因为它没有足够的资源来完成操作。 我的目标是将工作表 4 中 V13:XI1150 范
我正在尝试读取一个有 1147 行的文本文件。下面的代码仅读取第 1050-1147 行。我的目标是读取整个文件并提取位于不同行的特定值以在脚本中使用。一个示例是包含“BlockList: 2”的行中
我正在为游戏编写解释器。用户将其移动输入解释器,程序执行该移动。 现在我想为每个决定实现一个时间限制。玩家不应该能够思考超过 30 秒来写一个移动并按下回车。 call_with_time_limit
以this file例如,我正在尝试读取 data.frame 中的数据。来自 the doc (pdf 文件,表 1),它遵循一些 fortran 约定。我尝试了以下但收效甚微: dir 0' 将
我正在使用 R 阅读 Outlook 附件。我的引用在这里:Download attachment from an outlook email using R 这是我的电子邮件的截图: 这每天都会发送
我不会从表格中读取行来将主题放在列表中 php脚本 $url_obj='http://'.$host.':8069/xmlrpc/object'; $sock=new xmlrpc_client($u
我有一个这样的 csv 文件: id,name,value 1,peter,5 2,peter\,paul,3 我如何读取此文件并告诉 R "\," 不表示新列,仅表示 ","。 我必须添加该文件
我正在尝试读取 ~/Library/Preferences/com.apple.mail.plist (在 Snow Leopard 上)以获取电子邮件地址和其他信息以进入“关于”对话框。我使用以下代
This question already has answers here: How do I use floating-point division in bash? (19个回答) 5个月前关闭
本练习的目标是读取输入文件并将其存储到表中,然后验证输入中的某些字段并输出任何错误记录。我需要读取并存储每个策略组,以便表中一次仅存储 5 条记录,而不是整个文件。 所以我需要读取一个包含 5 条记录
据我了解,LWT 插入始终以 SERIAL 一致性级别完成。如果为 true,这是否意味着读取作为 LWT 插入的行可以安全地以 ANY 的一致性级别读取? 换句话说,我假设 LWT 插入是完全一致的
我看到很多很多通过java脚本读取cookie的函数,但我只想在变量中使用它一次,我是JS新手。 这是我的代码 var TheNumber = (Math.random() + '') * 10000
我正在使用 asp.net 和 C#。我在服务器上部署了一个应用程序[已发布],现在我想查看该网站的代码,据我所知,我可以阅读程序集来查看代码。 请告诉我如何实现它。 提前致谢。 最佳答案 您可以使用
我是一名优秀的程序员,十分优秀!