У меня есть DateTime
экземпляр с датой и временем. Как мне извлечь только дату или только время?
Ответы:
var day = value.Date; // a DateTime that will just be whole days
var time = value.TimeOfDay; // a TimeSpan that is the duration into the day
value.Date + ""
возвращает date 12:00:00 AM
. Используйте, value.Date.ToShortDateString()
чтобы избежать этого.
Вы также можете использовать DateTime.Now.ToString("yyyy-MM-dd")
дату и DateTime.Now.ToString("hh:mm:ss")
время.
Вы можете использовать Instance.ToShortDateString () для даты
и Instance.ToShortTimeString () для времени, чтобы получить дату и время из одного и того же экземпляра.
var currentDateTime = dateTime.Now();
var date=currentDateTime.Date;
yourDateObj.ToShortDateString();
Иногда вам нужно, чтобы ваш GridView был таким простым, как:
<asp:GridView ID="grid" runat="server" />
Вы не хотите указывать какой-либо BoundField, вы просто хотите привязать свою сетку к DataReader. Следующий код помог мне отформатировать DateTime в этой ситуации.
protected void Page_Load(object sender, EventArgs e)
{
grid.RowDataBound += grid_RowDataBound;
// Your DB access code here...
// grid.DataSource = cmd.ExecuteReader(CommandBehavior.CloseConnection);
// grid.DataBind();
}
void grid_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType != DataControlRowType.DataRow)
return;
var dt = (e.Row.DataItem as DbDataRecord).GetDateTime(4);
e.Row.Cells[4].Text = dt.ToString("dd.MM.yyyy");
}
Результаты показаны здесь.