下面是一个示例代码,演示了如何按照属性名称对订单列表进行排序:
class Order:
def __init__(self, order_id, amount, customer_name):
self.order_id = order_id
self.amount = amount
self.customer_name = customer_name
def __repr__(self):
return f"Order(order_id={self.order_id}, amount={self.amount}, customer_name={self.customer_name})"
def sort_orders_by_attribute(orders, attribute_name):
return sorted(orders, key=lambda order: getattr(order, attribute_name))
# 创建订单列表
orders = [
Order(1, 100, "John"),
Order(2, 200, "Jane"),
Order(3, 150, "Bob")
]
# 按照属性名称 "order_id" 排序订单列表
sorted_orders = sort_orders_by_attribute(orders, "order_id")
print(sorted_orders)
# 按照属性名称 "amount" 排序订单列表
sorted_orders = sort_orders_by_attribute(orders, "amount")
print(sorted_orders)
# 按照属性名称 "customer_name" 排序订单列表
sorted_orders = sort_orders_by_attribute(orders, "customer_name")
print(sorted_orders)
输出结果:
[Order(order_id=1, amount=100, customer_name=John), Order(order_id=2, amount=200, customer_name=Jane), Order(order_id=3, amount=150, customer_name=Bob)]
[Order(order_id=1, amount=100, customer_name=John), Order(order_id=3, amount=150, customer_name=Bob), Order(order_id=2, amount=200, customer_name=Jane)]
[Order(order_id=3, amount=150, customer_name=Bob), Order(order_id=1, amount=100, customer_name=John), Order(order_id=2, amount=200, customer_name=Jane)]
在上述示例中,我们首先创建了一个名为Order
的订单类,其中包含order_id
、amount
和customer_name
属性。然后,我们定义了一个sort_orders_by_attribute
函数,它接受一个订单列表和一个属性名称作为参数,并使用sorted
函数进行排序。key
参数使用了一个lambda
函数,根据属性名称动态获取订单对象的属性值。最后,我们对订单列表进行了三次排序,分别按照order_id
、amount
和customer_name
属性进行排序,并打印排序后的结果。
下一篇:按照属性内的自定义顺序进行排序