我正在使用Python操作一些数据,这些数据仅包含部件号及其与其他部件的关系(父/子)。这些零件位于物料清单(BOM)的多个层面。在Python中存储这些数据的最佳方法是什么?
最初,我使用了如下所示的嵌套字典,其中包含通用部件号以便于阅读(实际部件名称是随机字符)。但是,我并不认为将数据(部件名称)存储为字典键是一种很好的方法,因为它使得检索部件名称变得困难。
>>> BOM = {}
>>> BOM['Part 1'] = {}
>>> BOM['Part 1']['Part 1.1'] = {}
>>> BOM['Part 1']['Part 1.1']['Part 1.1.1'] = {}
>>> BOM['Part 1']['Part 1.2'] = {}
>>> BOM['Part 1']['Part 1.3'] = {}
>>> BOM['Part 2'] = {}
>>> BOM['Part 2']['Part 2.1'] = {}
>>> BOM['Part 2']['Part 2.2'] = {}
>>> BOM['Part 2']['Part 2.2']['Part 2.2.1'] = {}
>>> print(BOM)
{'Part 1': {'Part 1.1': {'Part 1.1.1': {}}, 'Part 1.2': {}, 'Part 1.3': {}}, 'Part 2': {'Part 2.1': {}, 'Part 2.2': {}, 'Part 2.2.1': {}}}
如果不是嵌套字典,我应该如何存储这些部分?或者我应该以不同方式使用嵌套字典吗?
答案 0 :(得分:1)
父/子关系通常存储为树。 anytree支持此类数据结构。这样您就可以轻松检索节点的名称。 如果部件只是在示例中递增1的数字,则一个简单的嵌套列表就足够了(嵌套列表的索引和深度意味着部件号的名称)。
答案 1 :(得分:1)
from anytree import Node
bom = {} # dictionary with part as key and list of nodes as value, ex. bom[part] = [Node(part), Node(part), ...]
for (part, parent) in part_list:
if part not in bom:
# Create key and initialize value if not in bom
bom[part] = []
if parent in bom:
# Add part to all instances of parent
for parent_node in bom[parent]:
bom[part].append(Node(part, parent=parent_node))
else:
# If part has no parents, just create the node
bom[part].append(Node(part))
答案 2 :(得分:0)
根据我的经验,如果字典中的元素没有值,它将被添加为字典中的列表。喜欢:
{'Part 1': {'Part 1.1': ['Part 1.1.1'], 'Part 1.2': {}, 'Part 1.3': {}}, 'Part 2': ['Part 2.1', 'Part 2.2', 'Part 2.2.1']}