31 lines
1.2 KiB
Python
31 lines
1.2 KiB
Python
from django.db.models.aggregates import Sum
|
|
from apps.pm.models import ProductionPlan, SubProductionPlan
|
|
|
|
class PmService:
|
|
|
|
@classmethod
|
|
def update_plan_process_json(cls, plan:ProductionPlan):
|
|
"""
|
|
更新计划按工序统计字段
|
|
"""
|
|
ret = {}
|
|
subplans = SubProductionPlan.objects.filter(production_plan=plan, is_deleted=False)
|
|
qs = subplans.values('process', 'process__name', 'process__number').annotate(count=Sum('count'),
|
|
count_real=Sum('count_real'), count_ok=Sum('count_ok'), count_notok=Sum('count_notok'))
|
|
qs_list = list(qs)
|
|
for i in qs_list:
|
|
ret[i['process__number']] = {
|
|
'process':i['process'],
|
|
'process_number':i['process__number'],
|
|
'process_name':i['process__name'],
|
|
'count':i['count'],
|
|
'count_real':i['count_real'],
|
|
'count_ok':i['count_ok'],
|
|
'count_notok':i['count_notok'],
|
|
'rate': round((i['count_ok']/(i['count_ok']+i['count_notok']))*100,2) if (i['count_ok']+i['count_notok']) > 0 else 0
|
|
}
|
|
plan.process_json = ret
|
|
plan.save()
|
|
|
|
|