排序优化

This commit is contained in:
guanhuan
2025-04-18 13:22:25 +08:00
parent 9cfc8418ec
commit 66c745af3c
2 changed files with 20 additions and 31 deletions

View File

@@ -1754,29 +1754,17 @@ class ResMrpWorkOrder(models.Model):
aggregate_field = 'create_date:max'
if aggregate_field not in fields:
fields.append(aggregate_field)
res = super(ResMrpWorkOrder, self).read_group(
domain, fields, groupby, offset=offset, limit=limit, orderby=orderby, lazy=lazy
)
sorted_res = sorted(
res,
key=lambda x: self.parse_datetime(x.get('create_date', '')),
reverse=True
)
return sorted_res
orderby = "create_date desc"
def parse_datetime(self, value):
"""将字符串转换为 datetime 对象,处理空值和无效格式"""
if not value:
return datetime.min # 返回最小日期时间,确保排序稳定
try:
# 假设 value 是字符串(如 "2023-10-01 12:00:00"
return datetime.strptime(value, "%Y-%m-%d %H:%M:%S")
except (TypeError, ValueError):
# 如果已经是 datetime 对象,直接返回
if isinstance(value, datetime):
return value
# 其他无效格式返回最小日期时间
return datetime.min
return super(ResMrpWorkOrder, self).read_group(
domain,
fields,
groupby,
offset=offset,
limit=limit,
orderby=orderby,
lazy=lazy
)
class CNCprocessing(models.Model):

View File

@@ -760,17 +760,18 @@ class StockPicking(models.Model):
aggregate_field = 'create_date:max'
if aggregate_field not in fields:
fields.append(aggregate_field)
res = super(StockPicking, self).read_group(
domain, fields, groupby, offset=offset, limit=limit, orderby=orderby, lazy=lazy
)
sorted_res = sorted(
res,
key=lambda x: self.env['mrp.workorder'].sudo().parse_datetime(x.get('create_date', '')),
reverse=True
)
return sorted_res
orderby = "create_date desc"
return super(StockPicking, self).read_group(
domain,
fields,
groupby,
offset=offset,
limit=limit,
orderby=orderby,
lazy=lazy
)
class ReStockMove(models.Model):