提取优化

parent ec9077c3
...@@ -309,44 +309,47 @@ private List<ExtractTransDto> StandDataFormat(int hospitalId, int allotId, List< ...@@ -309,44 +309,47 @@ private List<ExtractTransDto> StandDataFormat(int hospitalId, int allotId, List<
t.HISDeptName = WriteDataHelper.HasValue(t.HISDeptName, t.Department); t.HISDeptName = WriteDataHelper.HasValue(t.HISDeptName, t.Department);
}); });
var data = results.GroupJoin(dict, outer => new { Department = outer.Department }, inner => new { Department = inner.HISDeptName }, (outer, inner) => new { outer, inner }) var data = new List<ExtractTransDto>();
.Select(t => foreach (var item in results)
{
var firstDic = dict.FirstOrDefault(w => w.HISDeptName == item.Department) ?? dict.FirstOrDefault(w => w.Department == item.Department);
var dept = !string.IsNullOrEmpty(firstDic?.Department) ? firstDic?.Department : item.Department;
var d = new ExtractTransDto
{ {
var dept = !string.IsNullOrEmpty(t.inner.FirstOrDefault()?.Department) ? t.inner.FirstOrDefault()?.Department : t.outer.Department; SheetName = item.Source,
return new ExtractTransDto Department = dept,
{ Category = item.Category,
SheetName = t.outer.Source, DoctorName = item.DoctorName,
Department = dept, PersonnelNumber = item.PersonnelNumber,
Category = t.outer.Category, Value = item.Fee ?? 0,
DoctorName = t.outer.DoctorName, OutDoctorAccounting = firstDic?.OutDoctorAccounting?.AccountingUnit,
PersonnelNumber = t.outer.PersonnelNumber, OutNurseAccounting = firstDic?.OutNurseAccounting?.AccountingUnit,
Value = t.outer.Fee ?? 0, OutTechnicAccounting = firstDic?.OutTechnicAccounting?.AccountingUnit,
OutDoctorAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.OutDoctorAccounting?.AccountingUnit, InpatDoctorAccounting = firstDic?.InpatDoctorAccounting?.AccountingUnit,
OutNurseAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.OutNurseAccounting?.AccountingUnit, InpatNurseAccounting = firstDic?.InpatNurseAccounting?.AccountingUnit,
OutTechnicAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.OutTechnicAccounting?.AccountingUnit, InpatTechnicAccounting = firstDic?.InpatTechnicAccounting?.AccountingUnit,
InpatDoctorAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.InpatDoctorAccounting?.AccountingUnit, SpecialAccounting = firstDic?.SpecialAccounting?.AccountingUnit ?? dept,
InpatNurseAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.InpatNurseAccounting?.AccountingUnit, EName = types.FirstOrDefault(w => w.Id == item.TypeId)?.EName,
InpatTechnicAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.InpatTechnicAccounting?.AccountingUnit, };
SpecialAccounting = t.inner.FirstOrDefault(f => f.Department == dept)?.SpecialAccounting?.AccountingUnit ?? dept, data.Add(d);
EName = types.FirstOrDefault(w => w.Id == t.outer.TypeId)?.EName, }
};
});
var groupdata = data.GroupBy(t => new { t.Department, t.Category, t.SheetName }).Select(t => new ExtractTransDto var groupdata = data.GroupBy(t => new { t.Department, t.Category, t.SheetName })
{ .Select(t => new ExtractTransDto
SheetName = t.Key.SheetName, {
Department = t.Key.Department, SheetName = t.Key.SheetName,
Category = t.Key.Category, Department = t.Key.Department,
Value = t.Sum(group => group.Value) == 0 ? null : t.Sum(group => group.Value), Category = t.Key.Category,
OutDoctorAccounting = t.FirstOrDefault()?.OutDoctorAccounting, Value = t.Sum(group => group.Value) == 0 ? null : t.Sum(group => group.Value),
OutNurseAccounting = t.FirstOrDefault()?.OutNurseAccounting, OutDoctorAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.OutDoctorAccounting))?.OutDoctorAccounting,
OutTechnicAccounting = t.FirstOrDefault()?.OutTechnicAccounting, OutNurseAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.OutNurseAccounting))?.OutNurseAccounting,
InpatDoctorAccounting = t.FirstOrDefault()?.InpatDoctorAccounting, OutTechnicAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.OutTechnicAccounting))?.OutTechnicAccounting,
InpatNurseAccounting = t.FirstOrDefault()?.InpatNurseAccounting, InpatDoctorAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.InpatDoctorAccounting))?.InpatDoctorAccounting,
InpatTechnicAccounting = t.FirstOrDefault()?.InpatTechnicAccounting, InpatNurseAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.InpatNurseAccounting))?.InpatNurseAccounting,
SpecialAccounting = t.FirstOrDefault()?.SpecialAccounting, InpatTechnicAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.InpatTechnicAccounting))?.InpatTechnicAccounting,
EName = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.EName))?.EName SpecialAccounting = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.SpecialAccounting))?.SpecialAccounting,
}); EName = t.FirstOrDefault(w => !string.IsNullOrEmpty(w.EName))?.EName
});
return groupdata.ToList(); return groupdata.ToList();
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment