《Python编程的术与道:Python语言入门》视频课程
《Python编程的术与道:Python语言入门》视频课程链接:https://edu.csdn.net/course/detail/27845
嵌套是我们迄今为止最强大的概念之一。 嵌套涉及将列表或字典放在另一个列表或字典中。 通过嵌套,可以在程序中建模信息的能力大大扩展。
字典嵌套:我们在这里看两个例子,一个是字典中的列表,另一个是字典中的字典。
字典连接两条信息。 这两条信息可以是Python中的任何类型的数据结构。
我们使用字符串作为键,但将列表作为值。
第一个例子涉及存储一些人最喜欢的数字。 key由人名组成,值是每个人最喜欢的数字列表。 在第一个例子中,我们将逐个访问每个人的列表。
# This program stores people's favorite numbers, and displays them.
favorite_numbers = {'eric': [3, 11, 19, 23, 42],
'ever': [2, 4, 5],
'willie': [5, 35, 120],
}
# Display each person's favorite numbers.
print("Eric's favorite numbers are:")
print(favorite_numbers['eric'])
print("\nEver's favorite numbers are:")
print(favorite_numbers['ever'])
print("\nWillie's favorite numbers are:")
print(favorite_numbers['willie'])
Eric's favorite numbers are:
[3, 11, 19, 23, 42]
Ever's favorite numbers are:
[2, 4, 5]
Willie's favorite numbers are:
[5, 35, 120]
让我们使用for循环来遍历字典中的键:
# This program stores people's favorite numbers, and displays them.
favorite_numbers = {'eric': [3, 11, 19, 23, 42],
'ever': [2, 4, 5],
'willie': [5, 35, 120],
}
# Display each person's favorite numbers.
for name in favorite_numbers:
print("\n%s's favorite numbers are:" % name.title())
print(favorite_numbers[name])
Eric's favorite numbers are:
[3, 11, 19, 23, 42]
Ever's favorite numbers are:
[2, 4, 5]
Willie's favorite numbers are:
[5, 35, 120]
下面我们使用for循环分别打印喜欢的数字,但不使用列表。
# This program stores people's favorite numbers, and displays them.
favorite_numbers = {'eric': [3, 11, 19, 23, 42],
'ever': [2, 4, 5],
'willie': [5, 35, 120],
}
# Display each person's favorite numbers.
for name in favorite_numbers:
print("\n%s's favorite numbers are:" % name.title())
# Each value is itself a list, so we need another for loop
# to work with the list.
for favorite_number in favorite_numbers[name]:
print(favorite_number)
Eric's favorite numbers are:
3
11
19
23
42
Ever's favorite numbers are:
2
4
5
Willie's favorite numbers are:
5
35
120
在for循环中,可以将列表存储在一个新变量中,并使用它来定义你的for循环:
# This program stores people's favorite numbers, and displays them.
favorite_numbers = {'eric': [3, 11, 19, 23, 42],
'ever': [2, 4, 5],
'willie': [5, 35, 120],
}
# Display each person's favorite numbers.
for name in favorite_numbers:
print("\n%s's favorite numbers are:" % name.title())
# Each value is itself a list, so let's put that list in a variable.
current_favorite_numbers = favorite_numbers[name]
for favorite_number in current_favorite_numbers:
print(favorite_number)
Eric's favorite numbers are:
3
11
19
23
42
Ever's favorite numbers are:
2
4
5
Willie's favorite numbers are:
5
35
120
现在要介绍的最强大的嵌套概念是在字典中嵌套字典。
嵌套字典的创建方法与普通字典的创建方法相同。 唯一的区别是每个值都是另一个字典。
要创建嵌套字典,只需将字典的键值对作为关键字参数传递给dict()构造函数。
Example: 创建带有关键字参数的嵌套字典
D = dict(emp1 = {'name': 'Bob', 'job': 'Mgr'},
emp2 = {'name': 'Kim', 'job': 'Dev'},
emp3 = {'name': 'Sam', 'job': 'Dev'})
print(D)
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}, 'emp3': {'name': 'Sam', 'job': 'Dev'}}
可以将dict()函数与zip()函数一起使用,以组合在运行时动态获取的键和值的单独列表。
Example: Create a nested dictionary with list of zipped keys/values
IDs = ['emp1','emp2','emp3']
EmpInfo = [{'name': 'Bob', 'job': 'Mgr'},
{'name': 'Kim', 'job': 'Dev'},
{'name': 'Sam', 'job': 'Dev'}]
D = dict(zip(IDs, EmpInfo))
print(D)
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}, 'emp3': {'name': 'Sam', 'job': 'Dev'}}
经常需要创建一个字典,其中每个键都有默认值。 fromkeys()方法提供了一种方法。
Example: 使用默认值初始化嵌套字典
IDs = ['emp1','emp2','emp3']
Defaults = {'name': '', 'job': ''}
D = dict.fromkeys(IDs, Defaults)
print(D)
{'emp1': {'name': '', 'job': ''}, 'emp2': {'name': '', 'job': ''}, 'emp3': {'name': '', 'job': ''}}
可以通过在多个方括号中指定键来访问嵌套字典中的单个元素。
Example: Print the name of ’emp1′ and the job of ’emp2′
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
print(D['emp1']['name']) # Bob
print(D['emp2']['job']) # Dev
Bob
Dev
如果嵌套字典中没有某个键,则会引发异常。
Example: Trying to print salary of employee ’emp1′
# KeyError: 'salary'
print(D['emp1']['salary'])
---------------------------------------------------------------------------
KeyError Traceback (most recent call last)
<ipython-input-9-1656a1c760fe> in <module>
1 # KeyError: 'salary'
----> 2 print(D['emp1']['salary'])
KeyError: 'salary'
为避免此类异常,可以使用特殊的字典get()方法。
如果key在字典中,则此方法返回key的值,否则返回None,因此该方法永远不会引发KeyError。
Example: Access nested dictionary with get() method
# key present
print(D['emp1'].get('name')) # Bob
Bob
# key absent
print(D['emp1'].get('salary')) #None
None
要更改嵌套字典中特定元素的值,可通过指定相应的键。
Example: Change ’emp3′ record
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
D['emp3']['name'] = 'Max'
D['emp3']['job'] = 'Janitor'
print(D['emp3']) # {'name': 'Max', 'job': 'Janitor'}
{'name': 'Max', 'job': 'Janitor'}
添加或更新嵌套字典元素很容易。 只需按其键引用该元素并赋值即可。
如果字典中已经存在该键,则其值将被新的值替换。
Example: Update ’emp3′ record
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
D['emp3'] = {'name': 'Max', 'job': 'Janitor'}
print(D)
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}, 'emp3': {'name': 'Max', 'job': 'Janitor'}}
如果键是新键,则将键及其值添加到字典中。
Example: Add new record ’emp4′ to the dictionary
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
D['emp4'] = {'name': 'Max', 'job': 'Janitor'}
print(D)
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}, 'emp3': {'name': 'Sam', 'job': 'Dev'}, 'emp4': {'name': 'Max', 'job': 'Janitor'}}
使用内置的update()方法将一个嵌套字典的键和值合并到另一个字典中。
如果发生冲突,此方法会覆盖同一键的值。
Example: Merge dictionary ‘D2’ into ‘D1’
D1 = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'}}
D2 = {'emp2': {'name': 'Sam', 'job': 'Dev'},
'emp3': {'name': 'Max', 'job': 'Janitor'}}
D1.update(D2)
print(D1)
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Sam', 'job': 'Dev'}, 'emp3': {'name': 'Max', 'job': 'Janitor'}}
在将“ emp3”添加到字典的同时,“ emp2”也被更新。
如果知道所需元素的键,则可以使用pop()方法。 它删除键并返回其值。
Example: Remove key ’emp3′ and return its value
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
x = D.pop('emp3')
print(D) # {'emp1': {'name': 'Bob', 'job': 'Mgr'},
# 'emp2': {'name': 'Kim', 'job': 'Dev'}}
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}}
# removed value
print(x) # {'name': 'Sam', 'job': 'Dev'}
{'name': 'Sam', 'job': 'Dev'}
如果不需要删除的值,可使用del语句。
示例:删除键“emp3”
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
del D['emp3']
print(D) # {'emp1': {'name': 'Bob', 'job': 'Mgr'},
# 'emp2': {'name': 'Kim', 'job': 'Dev'}}
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}}
popitem()方法删除并最后插入的元素作为元组返回。
Example: 删除最后插入的元素
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
x = D.popitem()
print(D) # {'emp1': {'name': 'Bob', 'job': 'Mgr'},
# 'emp2': {'name': 'Kim', 'job': 'Dev'}}
{'emp1': {'name': 'Bob', 'job': 'Mgr'}, 'emp2': {'name': 'Kim', 'job': 'Dev'}}
# removed pair
print(x) # ('emp3', {'name': 'Sam', 'job': 'Dev'})
('emp3', {'name': 'Sam', 'job': 'Dev'})
在3.7之前的版本中,popitem()会删除一个随机元素。
可以使用嵌套的for循环遍历嵌套字典中的所有值。
Example: 遍历嵌套字典中的值
D = {'emp1': {'name': 'Bob', 'job': 'Mgr'},
'emp2': {'name': 'Kim', 'job': 'Dev'},
'emp3': {'name': 'Sam', 'job': 'Dev'}}
for id, info in D.items():
print("\nEmployee ID:", id)
for key in info:
print(key + ':', info[key])
Employee ID: emp1
name: Bob
job: Mgr
Employee ID: emp2
name: Kim
job: Dev
Employee ID: emp3
name: Sam
job: Dev
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[
下面例子中的Nested和Child有什么区别?是否只是同一事物的不同语法?classParentclassNested...endendclassChild 最佳答案 不,它们是不同的。嵌套:Computer之外的“Processor”类只能作为Computer::Processor访问。嵌套为内部类(namespace)提供上下文。对于ruby解释器Computer和Computer::Processor只是两个独立的类。classComputerclassProcessor#Tocreateanobjectforthisc
我的假设是moduleAmoduleBendend和moduleA::Bend是一样的。我能够从thisblog找到解决方案,thisSOthread和andthisSOthread.为什么以及什么时候应该更喜欢紧凑语法A::B而不是另一个,因为它显然有一个缺点?我有一种直觉,它可能与性能有关,因为在更多命名空间中查找常量需要更多计算。但是我无法通过对普通类进行基准测试来验证这一点。 最佳答案 这两种写作方法经常被混淆。首先要说的是,据我所知,没有可衡量的性能差异。(在下面的书面示例中不断查找)最明显的区别,可能也是最著名的,是你的
我有一个名为posts的模型,它有很多附件。附件模型使用回形针。我制作了一个用于创建附件的独立模型,效果很好,这是此处说明的View(https://github.com/thoughtbot/paperclip):@attachment,:html=>{:multipart=>true}do|form|%>posts中的嵌套表单如下所示:prohibitedthispostfrombeingsaved:@attachment,:html=>{:multipart=>true}do|at_form|%>附件记录已创建,但它是空的。文件未上传。同时,帖子已成功创建...有什么想法吗?
我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o