python入门基础(8)–python中的嵌套

嵌套:将一系列字典存储在列表中,或将列表作为值存储在字典中,这称为嵌套。既可以在列表中嵌套字典,也可以在字典中嵌套列表,甚至在字典中嵌套字典

一、列表中嵌套字典 

1)一般创建方式:

student_A ={'name':'Allen','age':'14','grade':'8'} 
student_B ={'name':'Jack','age':'12','grade':'6'} 
student_C ={'name':'Lucy','age':'13','grade':'7'} 
student_D ={'name':'polo','age':'14','grade':'8'} 
#上述四行,创建了4个字典,每个字典代表一个学生
students=[student_A,student_B,student_C,student_D]#将上述4个学生放名为students的列表中

for student in students:  #遍历students列表
    print(student)        #打印每个学生
print("n")  

 2)批量创建同类型的字典,比如游戏中很多同类型小兵

#创建更多的同类型的字典
ghosts=[]      #创建一个空ghosts列表
for ghost_number in range(10):  #创建10个ghost,注意range(10)是从0-9
    new_ghost={'name':'rubbish','life':'10','speed':'1'}    #同类型的名字rubbish,颜色为green,生命力为10,速度为1
    ghosts.append(new_ghost)   #append()是将创建的new_ghost放到列表ghosts最后
    
for ghost in ghosts:   #遍历创建的ghosts列表
    print(ghost)   #打印ghosts中的每个元素,即10个同类型的ghost
    
print("Total number of ghosts:"+str(len(ghosts)))    #打印ghosts列表中元素的个数,len()求元素个数,str()转为字符串

 3)同类型的字典,可通过循环,及切片进行增、删、改等操作。

for ghost in ghosts[0:3]: 
    if ghost['color'] == 'green':
        ghost['color'] = 'yellow'
        ghost['speed'] = 2
        ghost['life'] = 5
for ghost in ghosts:   
    print(ghost)    

运行如果:

python入门基础(8)--python中的嵌套

 二、字典中嵌套列表

比如在实际生活中,描述菜单,如果使用列表,只能存储菜肴的配料;但如果使用字典,就不仅可在其中包含配料列表,还可包含其他有关描述。
如下示例,存储了菜单的两方面信息:菜肴类型和配料列表。
其中的配料列表是一个与键 'toppings' (佐料)相关联的值。
要访问该列表,使用字典名和键 'toppings' ,就像访问字典中的其他值一样,这将返回一个配料列表,而不是单个值

1)嵌套一个列表

# 存储所点菜单的信息
menu = {  # 定义一个菜单字典
'style': 'sichuan',   #定义菜单的类型,四川菜
'toppings': ['salt', 'sugar','vinegar','Sichuan Pepper']  # 定义一个佐料的列表,包含盐、糖、醋、花椒
}   #存储了有关顾客所点菜肴的信息
# 概述所点的菜单
print("You ordered a " + menu['style'] + "-style menu " +
"with the following toppings:")  
for topping in menu['toppings']:
          print("t" + topping)

2)嵌套多个列表

favor_languages = {
'jack': ['python', 'ruby'],
'sarah': ['c','C++'],
'edward': ['ruby', 'go'],
'polo':['c#','java']
}
for name, languages in favor_languages.items(): 
    print("n" + name.title() + "'s favorite languages are:")
    for language in languages:
        print("t" + language.title())     

 

三、在字典中存储字典

网站有多个用户,每个都有独特ID(或用户名),可以在字典中将用户名作为键,再将每位用户的信息存储在一个字典中,并将该字典作为与用户名相关联的值。对于每位用户,都存储了其三项信息:名、姓和居住地;为访问这些信息,遍历所有的用户名,并访问与每个用户名相关联的信息字典

#在字典中嵌套字典
users = {    #创建一个users的字典,字典中有两个关键字(id)lucyb和merryb,
'lucyb': {'firstname': 'lucy','lastname':'Bush','location': 'califorlia'},
'merryb':{'firstname':'merry','lastname':'Biden','location':'San Francisco'}
}  # lucyb和merryb又分别为两字典,各自有三个关键字,firstname,lastname和location

for username, user_info in users.items():  #遍历字典uers的每一项
    print("nUsername: " + username) 
    full_name = user_info['firstname'] + " " + user_info['lastname']
    location = user_info['location']
    print("tFull name: " + full_name.title())
    print("tLocation: " + location.title())  

运行结果:

python入门基础(8)--python中的嵌套

 

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:python入门基础(8)–python中的嵌套 - Python技术站

(0)
上一篇 2023年4月2日 下午5:47
下一篇 2023年4月2日

相关文章

  • python入门基础(11)–类的导入、继承及使用

    在上篇“python中的类的创建、使用和继承”中,创建了Person()和Student()两个类,最后才是程序执行主体,如下:  class Person(): #创建一个person类,父类必须包含在当前文件中,且位于子类前面。 def __init__(self, name, age,hometown): #父类 self.name = name se…

    2023年4月2日
    00
  • Python数据分析–Numpy常用函数介绍(6)–Numpy中与股票成交量有关的计算

            成交量(volume)是投资中一个非常重要的变量,它是指在某一时段内具体的交易数,可以在分时图中绘制,包括日线图、周线图、月线图甚至是5分钟、30分钟、60分钟图中绘制。   股票市场成交量的变化反映了资金进出市场的情况,成交量是判断市场走势的重要指标。一般情况下,成交量大且价格上涨的股票,趋势向好。成交量持续低迷时,一般出现在熊市或股票整理…

    2023年4月2日
    00
  • python入门基础(6)–语句基础(if语句、while语句)

    一、if语句 if 语句让你能够检查程序的当前状态,并据此采取相应的措施。if语句可应用于列表,以另一种方式处理列表中的大多数元素,以及特定值的元素1、简单示例 names=[‘xiaozhan’,’caiyilin’,’zhoushen’,’DAOlang’,’huangxiaoming’] for name in names: if name == ‘c…

    2023年4月2日
    00
  • Python数据分析–Numpy常用函数介绍(7)–Numpy中矩阵和通用函数

    在NumPy中,矩阵是 ndarray 的子类,与数学概念中的矩阵一样,NumPy中的矩阵也是二维的,可以使用 mat 、 matrix 以及 bmat 函数来创建矩阵。 一、创建矩阵 mat 函数创建矩阵时,若输入已为 matrix 或 ndarray 对象,则不会为它们创建副本。 因此,调用 mat() 函数和调用 matrix(data, copy=F…

    2023年4月2日
    00
  • python入门基础(5)–数值列表、切片及元组

    列表也非常适合存储一组数字,尤其是大数据处理,处理的几乎都是由数字(如气温、距离、人口数量、经济等)组成的集合。 Python提供很多工具,在数据可视化中,可高效地处理数字列表。 一、数值列表    range() 让你能够轻松地生成一系列的数字 for value in range(1,6):    print(value)# 显示结果为1,2,3,4,5…

    2023年4月2日
    00
  • Python数据分析–Numpy常用函数介绍(1)–工具安装及Numpy介绍

    Anaconda 是一个跨平台的版本,通过命令行来管理安装包。进行大规模数据处理、预测分析和科学计算。它包括近 200 个工具包,大数据处理需要用到的常见包有 NumPy 、 SciPy 、 pandas 、 IPython 、 Matplotlib 、 Scikit-learn 、gensim、nltk、networkx、beautifulsoup4和st…

    2023年4月2日
    00
  • Python数据分析–Numpy常用函数介绍(4)–Numpy中的线性关系和数据修剪压缩

    摘要:总结股票均线计算原理–线性关系,也是以后大数据处理的基础之一,NumPy的 linalg 包是专门用于线性代数计算的。作一个假设,就是一个价格可以根据N个之前的价格利用线性模型计算得出。     前一篇,在计算均线,指数均线时,分别计算了不同的权重,比如 和 都是按不同的计算方法来计算出相关的权重,一个股价可以用之前股价的线性组合表示出来,也即,这个…

    2023年4月2日
    00
  • python数据可视化-matplotlib入门(5)-饼图和堆叠图

    饼图常用于统计学模块,画饼图用到的方法为:pie( ) 一、pie()函数用来绘制饼图 pie(x, explode=None, labels=None, colors=None, autopct=None, pctdistance=0.6, shadow=False, labeldistance=1.1, startangle=0, radius=1, c…

    2023年4月2日
    00
合作推广
合作推广
分享本页
返回顶部