Konwertuję małą aplikację MSAccess do internetowej aplikacji ASP.NET, używając C# 3.5. Zastanawiam się, jaki jest najlepszy sposób pracy z datami w C#, przy konwersji niektórych z tego kodu VBA na C#.W języku C#, jak przekonwertować typ danych TimeSpan na DateTime?
Oto przykład kodu VBA:
Coverage1=IIf(IsNull([EffDate1]),0,IIf([CurrDate]<=[EndDate1],[CurrDate]-[EffDate1],[EndDate1]-[EffDate1]+1))
Oto co mój aktualny kod C# wygląda z błędów oznaczonych w komentowanym kodu:
public DateTime CalculateCoverageOne(DateTime dateEffDateOne, DateTime dateCurrentDate, DateTime dateEndDateOne)
{
if (dateCurrentDate.Date <= dateEndDateOne.Date)
{
return null; //Get "cannot convert null to System.DateTime because it is a non-nullable value type" error
}
else
{
if (dateCurrentDate.Date <= dateEndDateOne)
{
return dateCurrentDate.Subtract(dateEffDateOne); //Gets error "cannot implicitly convert system.timepsan to system.datetime
}
else
{
return dateEndDateOne.Subtract(dateEffDateOne.AddDays(1)); //Gets error "cannot implicitly convert system.timepsan to system.datetime
}
}
}
Najbardziej doskonały. Dziękuję Ci bardzo! – program247365