Python – 字典中的优先键分配

Python – 字典中的优先键分配

Python语言由各种数据结构组成,其中之一就是字典。字典数据结构中的元素是用逗号分隔,并放在花括号“{}”中。Python由于其简单性和灵活性与其他应用程序的结合而在全球范围内广受欢迎。除了其他语言之外,它因为具有易编码的简单语法和语句而占据了独特的地位。字典数据结构可以容纳大量数据集,基于优先级查找元素可能会很困难。

字典中的优先键分配

在Python语言的各种数据结构中,字典是一种复杂的数据结构。字典不遵循元素的任何顺序,并且无法更改分配的键值。字典可以容纳列表、元组或另一个字典等元素。字典的基本语法为,

Dict_1 = {‘hello’: ‘all’, ‘welcome’: 897}

在本文中,将介绍使用优先级元素对元素进行排序的方法,使用不同的方法进行解释。

在Python字典中分配优先键的方式允许开发人员根据其重要性为键分配优先级。通过为字典中的不同键分配优先级,我们可以确保它们以特定的顺序进行处理,而不管它们在代码整体结构中的位置如何。

优先键分配示例

想象一下拥有一套车队管理系统,每辆车都连接了多个传感器,提供关于其状态的实时更新,如速度、燃油消耗和发动机温度。但是,如果在创建每个传感器项(键)时使用“priority_key”参数,我们可以更好地控制字典的处理顺序,因为应该首先访问值较高的元素。

fleet_management = {'VehicleA': { 'EngineTemp': 45,'SpeedSensor': 65}, 
                    'VehicleB': { 'FuelConsumption' :34 ,'SpeedSensor' :80}}

在这种情况下,车辆A的引擎温度具有较低的整数值,接受高优先级值,而对于车辆B,速度传感器优于燃油消耗,因为它分配的整数值高于34。

因此,每次在循环/迭代中访问车队数据时,都会根据这些“priority_keys”值产生基于优先级的结果,这在处理不同优先级数据时非常有用。

方法

  • 方法1 – 使用匹配的元素

  • 方法2 – 使用迭代方法

方法1:使用匹配的元素在字典中打印优先键分配的Python程序

使用生成表达式来匹配列表和字典数据结构中的元素。

算法

  • 步骤1 - 使用字符串和键对初始化字典值。

  • 步骤2 - 使用一些其他字符串元素声明列表数据结构。

  • 步骤3 - 使用生成器表达式在列表和字典之间找到匹配的元素。

  • 步骤4 - 打印匹配或优先级的元素。

  • 步骤5 - 然后打印最终值。

示例

# Initialize a dictionary with some key-value pairs.
dict1 = {'Hello' : 9, 'to' : 6, 'Welcome' : 3, 'ALL' : 56}

# Initialize a list with some elements.
list1 = ['ALL', 'is', 'come']

# Get the matching element from list1 and dict1.
matching_element = next((a for a in list1 if a in dict1), None)

# Print the matching element.
print("Matching element is : " + str(matching_element))

# Print the value of matching_element.
print("Value of matching element is : " + str(dict1[matching_element]))

输出

Matching element is : ALL
Value of matching element is : 56

方法 2:使用迭代方法在字典中打印优先键分配的 Python 程序

字典数据结构和优先列表被初始化,并且当元素匹配时,返回优先键。当元素不匹配时,返回 none 值。

算法

  • 步骤 1 ‚àí 字典值被初始化为字符串值,并分配了一个键值。

  • 步骤 2 ‚àí 优先列表遵循列表数据结构,并包含一些用于匹配值的字符串。

  • 步骤 3 ‚àí 变量被赋值为 “None”。

  • 步骤 4 ‚àí 使用 for 循环来迭代给定的字典值。

  • 步骤 5 ‚àí 当当前值与字典匹配时,返回键值。

示例

#initializing the dictionary data structure
dict1 = {'Hello' : 9, 'to' : 6, 'Welcome' : 3, 'ALL' : 56}
#Declaring the priority list to match it with the dictionary data structure
prioritylist = ['ALL', 'John', 'Home']

#Declaring val as None
val = None
#for loop will iterate through the dictionary of values
for num in dict1:
#If the element is present in both dict1 and prioritylist
    if num in prioritylist :
        val = dict1[num]
        break
#Print function will return the priority element
print("Value of matching element is : " + str(val))

输出结果

Value of matching element is : 56

结论

在当前世界中,对于大量数据的组织来说,处理数据是最具挑战性的任务,并且随着数据科学和机器学习的发展,访问数据变得更加容易。Python是一种灵活且高级的语言,用户可以轻松理解。

Camera课程

Python教程

Java教程

Web教程

数据库教程

图形图像教程

办公软件教程

Linux教程

计算机教程

大数据教程

开发工具教程