LINQ: Как проверить наличие делителя нуля внутри типа?

#linq #zero

#linq #ноль

Вопрос:

Есть ли способ (без использования try catch) проверить наличие нуля в ps.sum ниже, чтобы он не выдавал ошибку деления на ноль?

 var procVsTotPkg = unitGroup.Join(procSums, g => new 
{
    g.DeptID,
    g.UnitLoc,
    g.Proc
},
ps => new
{                      
    DeptID = ps.key.deptID,
    UnitLoc = ps.key.unitLoc,
    Proc = ps.key.procName
}, (g, ps) => new procVSUnitTotalJoin
{
    dept = g.DeptID,
    uloc = g.UnitLoc,
    procName = g.Proc,
    unitName = g.Unit,
    unitTotal = g.CurrVal,
    procTotal = ps.sum,
    PTPcntOfUT = Math.Round((g.CurrVal / ps.sum) * 100, 2)
}).Single();
  

Ответ №1:

 PTPcntOfUT = ps.sum != 0 ? Math.Round((g.CurrVal/ps.sum)*100) : valueIfSumIsZero
  

Ответ №2:

Как насчет:

 (g, ps) => new procVSUnitTotalJoin
              {
                   dept = g.DeptID,
                   uloc = g.UnitLoc,
                   procName = g.Proc,
                   unitName = g.Unit,
                   unitTotal = g.CurrVal,
                   procTotal = ps.sum,
                   PTPcntOfUT = Math.Round((g.CurrVal / (ps.sum == 0 ? 1:ps.sum)) * 100, 2)
              }