本文整理匯總了C#中System.DateTime.GetValueOrDefault方法的典型用法代碼示例。如果您正苦於以下問題:C# DateTime.GetValueOrDefault方法的具體用法?C# DateTime.GetValueOrDefault怎麽用?C# DateTime.GetValueOrDefault使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類System.DateTime
的用法示例。
在下文中一共展示了DateTime.GetValueOrDefault方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: testNullableDateTimeGetValueOrDefault
public void testNullableDateTimeGetValueOrDefault()
{
DateTime? e = null;
DateTime def = e.GetValueOrDefault();
Assert.AssertEquals(default(DateTime), def);
e = new DateTime(2002, 2, 2);
def = e.GetValueOrDefault();
Assert.AssertEquals(new DateTime(2002, 2, 2), def);
e = null;
def = e.GetValueOrDefault();
Assert.AssertEquals( default(DateTime), def);
}
示例2: IsBirthday
internal static bool IsBirthday(DateTime? birthday)
{
DateTime bday = birthday.GetValueOrDefault();
if (bday > DateTime.Today)
return false;
return true;
}
示例3: Update
public void Update(Account selectedAccount, DateTime? start, DateTime? end)
{
Start = start;
End = end;
var transactions = Dao.Query(GetCurrentRange(start, end, x => x.AccountId == selectedAccount.Id)).OrderBy(x => x.Date);
Transactions = transactions.Select(x => new AccountDetailData(x, selectedAccount)).ToList();
if (start.HasValue)
{
var pastDebit = Dao.Sum(x => x.Debit, GetPastRange(start, x => x.AccountId == selectedAccount.Id));
var pastCredit = Dao.Sum(x => x.Credit, GetPastRange(start, x => x.AccountId == selectedAccount.Id));
var pastExchange = Dao.Sum(x => x.Exchange, GetPastRange(start, x => x.AccountId == selectedAccount.Id));
if (pastCredit > 0 || pastDebit > 0)
{
Summaries.Add(new AccountSummaryData(Resources.TransactionTotal, Transactions.Sum(x => x.Debit), Transactions.Sum(x => x.Credit)));
var detailValue =
new AccountDetailData(
new AccountTransactionValue
{
Date = start.GetValueOrDefault(),
Name = Resources.BalanceBroughtForward,
Credit = pastCredit,
Debit = pastDebit,
Exchange = pastExchange
}, selectedAccount) { IsBold = true };
Transactions.Insert(0, detailValue);
}
}
if (end.HasValue && end != start)
{
var futureDebit = Dao.Sum(x => x.Debit, GetFutureRange(end, x => x.AccountId == selectedAccount.Id));
var futureCredit = Dao.Sum(x => x.Credit, GetFutureRange(end, x => x.AccountId == selectedAccount.Id));
var futureExchange = Dao.Sum(x => x.Exchange, GetFutureRange(end, x => x.AccountId == selectedAccount.Id));
if (futureCredit > 0 || futureDebit > 0)
{
Summaries.Add(new AccountSummaryData(Resources.DateRangeTotal, Transactions.Sum(x => x.Debit), Transactions.Sum(x => x.Credit)));
var detailValue =
new AccountDetailData(
new AccountTransactionValue
{
Date = end.GetValueOrDefault(),
Name = Resources.BalanceAfterDate,
Credit = futureCredit,
Debit = futureDebit,
Exchange = futureExchange
}, selectedAccount) { IsBold = true };
Transactions.Add(detailValue);
}
}
Summaries.Add(new AccountSummaryData(Resources.GrandTotal, Transactions.Sum(x => x.Debit), Transactions.Sum(x => x.Credit)));
for (var i = 0; i < Transactions.Count; i++)
{
Transactions[i].Balance = (Transactions[i].Debit - Transactions[i].Credit);
if (i > 0) (Transactions[i].Balance) += (Transactions[i - 1].Balance);
}
}
示例4: AgeAt
public static int AgeAt(this DateTime dt, DateTime? atDate = null)
{
var ageAtDate = atDate.GetValueOrDefault(DateTime.UtcNow).Date;
var age = ageAtDate.Year - dt.Year;
if (dt > ageAtDate.AddYears(-age)) age--;
return age;
}
示例5: WithShoe
public static ShoeTrackerDbContext WithShoe(this ShoeTrackerDbContext context,
string name,
string userId,
DateTime? firstUsedDate=null,
DateTime? lastUsedDate=null,
decimal? maximumDistance=null,
string brand=null)
{
var maxShoeId = 1L;
if (context.Shoes.Any())
{
maxShoeId = context.Shoes.Max(s => s.ShoeId);
}
var shoe = new Shoe
{
CreatedAt = DateTime.Now,
FirstUsed = firstUsedDate.GetValueOrDefault(DateTime.Today),
LastUsed = lastUsedDate,
MaximumDistance = maximumDistance.GetValueOrDefault(400),
Name = name,
Brand = brand ?? "default brand",
Workouts = new List<Workout>(),
ShoeId = maxShoeId+1,
UserId = userId
};
context.Shoes.Attach(shoe);
return context;
}
示例6: WithWorkout
public static MapMyFitnessApi WithWorkout(this MapMyFitnessApi api,
int externalUserId,
string accessToken,
string name,
decimal? distanceInMiles = null,
string workoutId = null,
DateTime? workoutDate = null,
string activityType = "16",
DateTime? lastWorkoutImported = null)
{
var workouts = api.GetWorkoutsByUser(externalUserId, accessToken,lastWorkoutImported);
var distance = System.Convert.ToDouble(distanceInMiles.GetValueOrDefault(2)*(1/0.000621371m));
workouts.Add(new Workout
{
name = name,
start_datetime = workoutDate.GetValueOrDefault(DateTime.Now).ToString("yyyy'-'MM'-'dd'T'HH':'mm':'ss'.'fff'Z'"),
_links = new Links
{
self = new List<Next>
{
new Next { id = workoutId ?? Guid.NewGuid().ToString()}
},
activity_type = new List<Next>
{
new Next { id = activityType}
},
},
aggregates = new WorkoutAggregate { distance_total = distance}
});
api.GetWorkoutsByUser(externalUserId, accessToken, lastWorkoutImported).Returns(workouts);
return api;
}
示例7: CompletedChore
public CompletedChore(Chore c, DateTime? completionDate = null, string completedBy = "")
{
ChoreName = c.ChoreName;
CompletionDate = completionDate.GetValueOrDefault (DateTime.Now);
CompletedBy = completedBy;
ParentChoreId = c.ID;
}
示例8: Stop
public void Stop(DateTime? stopTime, string comment, IDateTimeService dateTimeService)
{
if (lastStartTime == null)
{
throw new InvalidOperationException("Task already stopped");
}
ApplyChange(new TaskStopped(id, stopTime.GetValueOrDefault(dateTimeService.GetUtcNow()), comment));
}
示例9: TryToAssignValue
/// <summary>
/// A method to try to assign the value of the nullable DateTime instance. If the value is null, check off DateTimePicker control. Assign the value to DateTimePicker.Value property otherwise.
/// </summary>
/// <param name="dateTimePicker">DateTimePicker control to execute method for.</param>
/// <param name="dateTime">Nullable DateTime instance to check for the value.</param>
public static void TryToAssignValue(this DateTimePicker dateTimePicker, DateTime? dateTime)
{
if(dateTime.GetValueOrDefault() < dateTimePicker.MinDate || dateTime.GetValueOrDefault() > dateTimePicker.MaxDate)
{
dateTime = null;
}
if(dateTime == null)
{
dateTimePicker.Value = DateTime.Now;
dateTimePicker.Checked = false;
}
else
{
dateTimePicker.Checked = true;
dateTimePicker.Value = (DateTime)dateTime;
}
}
示例10: EncodeDateTime
/// <summary>
///
/// </summary>
/// <param name="htmlHeler"></param>
/// <param name="value"></param>
/// <returns></returns>
public static string EncodeDateTime(this HtmlHelper htmlHeler, DateTime? value)
{
if (value == null)
{
return string.Empty;
}
return htmlHeler.EncodeDateTime(value.GetValueOrDefault());
}
示例11: IsATimeBiggerThanBTime
internal static bool IsATimeBiggerThanBTime(DateTime? ATime, DateTime? BTime)
{
DateTime atime = ATime.GetValueOrDefault();
DateTime btime = BTime.GetValueOrDefault();
if (atime > btime)
return true;
else
return false;
}
示例12: Generate
public static Employee Generate(string id = null, string name = null, int? age = null, string companyName = null, string companyId = null, DateTime? createdUtc = null, DateTime? updatedUtc = null) {
return new Employee {
Id = id,
Name = name ?? RandomData.GetAlphaString(),
Age = age ?? RandomData.GetInt(18, 100),
CompanyName = companyName ?? RandomData.GetAlphaString(),
CompanyId = companyId ?? ObjectId.GenerateNewId().ToString(),
CreatedUtc = createdUtc.GetValueOrDefault(),
UpdatedUtc = updatedUtc.GetValueOrDefault()
};
}
示例13: CalculateAge
public static int CalculateAge(DateTime? birthdate)
{
DateTime bday = birthdate.GetValueOrDefault(DateTime.Now);
var age = DateTime.Now.Year - bday.Year;
//om man inte fyllt år i år så tar den bort 1år från age för att få rätt ålder
if ((DateTime.Now.Month <= bday.Month) ||
(DateTime.Now.Day >= bday.Day && DateTime.Now.Month <= bday.Month)) age--;
return age;
}
示例14: Dates
/// <summary>
/// Returns random date gen
/// </summary>
/// <param name="min">if not supplied, DateTime.MinValue is used</param>
/// <param name="max">if not supplied, DateTime.MaxValue is used</param>
public Func<DateTime> Dates(DateTime? min = null, DateTime? max = null)
{
var minDate = min.GetValueOrDefault(DateTime.MinValue);
var maxDate = max.GetValueOrDefault(DateTime.MaxValue);
if (minDate >= maxDate)
throw new ArgumentOutOfRangeException("min >= max");
var ticksSpan = maxDate.Ticks - minDate.Ticks;
var factory = _random.Numbers.Doubles().BetweenZeroAndOne();
return () => new DateTime(Convert.ToInt64(minDate.Ticks + ((double)ticksSpan * factory())));
}
示例15: GetDettaglioPartitario
public List<MovimentoContabileBilancioDTO> GetDettaglioPartitario(EsercizioDTO esercizioDTO, IList<ContoDTO> conti, List<string> sottoconti, DateTime? dataIniziale, DateTime? dataFinale)
{
var idConti = conti.Select(conto => conto.ID).ToList();
if (esercizioDTO != null)
{
dataIniziale = esercizioDTO.DataApertura;
dataFinale = esercizioDTO.DataChiusura;
}
var result = GetServiceClient().GetDettaglioPartitario(idConti, sottoconti, dataIniziale.GetValueOrDefault(), dataFinale.GetValueOrDefault(), GetUserInfo());
CloseService();
return result;
}