假设有一个产品数据表,其中包含以下字段: 产品ID(product_id),产品名称(product_name),父级ID(parent_id)。现在需要编写一个函数,按照父级ID将产品列出。
以下是一个示例解决方法,使用Python编写一个函数来实现该功能:
def list_products_by_parent_id(products, parent_id, indent=0):
for product in products:
if product['parent_id'] == parent_id:
print(' ' * indent + product['product_name'])
list_products_by_parent_id(products, product['product_id'], indent + 4)
使用示例:
products = [
{'product_id': 1, 'product_name': '产品1', 'parent_id': None},
{'product_id': 2, 'product_name': '产品2', 'parent_id': None},
{'product_id': 3, 'product_name': '产品1.1', 'parent_id': 1},
{'product_id': 4, 'product_name': '产品1.2', 'parent_id': 1},
{'product_id': 5, 'product_name': '产品1.1.1', 'parent_id': 3},
{'product_id': 6, 'product_name': '产品2.1', 'parent_id': 2},
]
# 列出所有产品
list_products_by_parent_id(products, None)
输出结果:
产品1
产品1.1
产品1.1.1
产品1.2
产品2
产品2.1
该示例代码使用递归的方式,通过比较每个产品的父级ID来确定是否需要打印该产品。如果父级ID与指定的父级ID相同,则打印该产品,并通过递归调用函数来查找该产品的子产品,并将缩进增加4个空格用于展示层级关系。这样就可以按照父级ID列出产品。