DateTime.ParseExact 没有按照我的意愿去做
DateTime.ParseExact is not doing what i want it to do
当对 DateTime 使用 .ParseExact() 方法时,我总是得到与我输入的字符串相同的输出。这是我的代码:
[Authorize(Roles = "Backoffice, Manager")]
[HttpPost]
public ActionResult FilmShowCreate(FilmShowViewModel newFilmShow)
{
if (ModelState.IsValidField("FilmId") && ModelState.IsValidField("Time"))
{
DateTime unformattedDateTime = newFilmShow.Date.Date + newFilmShow.Time.TimeOfDay;
string dateString = unformattedDateTime.ToString("yyyy-MM-dd HH:mm:ss");
DateTime dbDate = DateTime.ParseExact(dateString, "yyyy-MM-dd HH:mm:ss",
CultureInfo.GetCultureInfo("en-US"), DateTimeStyles.AdjustToUniversal);
FilmShow filmShow = new FilmShow
{
Film = filmRepository.GetFilm(newFilmShow.FilmId),
Cinema = cinemaRepository.GetCinema(newFilmShow.CinemaId),
ThreeDimensional = newFilmShow.ThreeDimensional,
Date = dbDate,
SpecialEvent = newFilmShow.SpecialEvent
};
filmShowsRepository.AddShow(filmShow);
return View("SuccesfullFilmShowCreate");
字符串 dateString 的格式很好,但它是一个字符串,我需要将它作为 DateTime 格式存储在数据库中,就像这样 "year-month-day hours:minutes:seconds"。但无论出于何种原因,ParseExact 似乎不适用于我的情况。我得到的 DateTime 格式是 "dd-MM-yyyy HH:mm".
它没有按照您的要求进行操作,因为,好吧,该函数 不应该 进行您所描述的操作。
ParseExact
只是表示 input 必须匹配给定的格式才能使用(并且不会抛出异常)。它是 Parse
的对应物,它将接受任何有效的 Date/Time 格式。 它绝对不会影响它创建的 DateTime
对象的任何字符串表示形式的未来格式。
如果你想输出给定的格式,在将你的格式字符串发送到数据库之前,将你的格式字符串传递给ToString
。当然,如果您使用的是 EF 之类的工具,那么转换已经为您完成,这无关紧要。
示例:
string myFormattedDateTime = dbDate.ToString("yyyy-MM-dd HH:mm:ss");
仔细阅读您的问题,我意识到您似乎认为 DateTime 具有某种 "stored" 格式。它不是。 DateTime 只是一个数字集合,其中包含表示日期和时间所需的信息。您描述的格式仅存在于字符串表示中。
当对 DateTime 使用 .ParseExact() 方法时,我总是得到与我输入的字符串相同的输出。这是我的代码:
[Authorize(Roles = "Backoffice, Manager")]
[HttpPost]
public ActionResult FilmShowCreate(FilmShowViewModel newFilmShow)
{
if (ModelState.IsValidField("FilmId") && ModelState.IsValidField("Time"))
{
DateTime unformattedDateTime = newFilmShow.Date.Date + newFilmShow.Time.TimeOfDay;
string dateString = unformattedDateTime.ToString("yyyy-MM-dd HH:mm:ss");
DateTime dbDate = DateTime.ParseExact(dateString, "yyyy-MM-dd HH:mm:ss",
CultureInfo.GetCultureInfo("en-US"), DateTimeStyles.AdjustToUniversal);
FilmShow filmShow = new FilmShow
{
Film = filmRepository.GetFilm(newFilmShow.FilmId),
Cinema = cinemaRepository.GetCinema(newFilmShow.CinemaId),
ThreeDimensional = newFilmShow.ThreeDimensional,
Date = dbDate,
SpecialEvent = newFilmShow.SpecialEvent
};
filmShowsRepository.AddShow(filmShow);
return View("SuccesfullFilmShowCreate");
字符串 dateString 的格式很好,但它是一个字符串,我需要将它作为 DateTime 格式存储在数据库中,就像这样 "year-month-day hours:minutes:seconds"。但无论出于何种原因,ParseExact 似乎不适用于我的情况。我得到的 DateTime 格式是 "dd-MM-yyyy HH:mm".
它没有按照您的要求进行操作,因为,好吧,该函数 不应该 进行您所描述的操作。
ParseExact
只是表示 input 必须匹配给定的格式才能使用(并且不会抛出异常)。它是 Parse
的对应物,它将接受任何有效的 Date/Time 格式。 它绝对不会影响它创建的 DateTime
对象的任何字符串表示形式的未来格式。
如果你想输出给定的格式,在将你的格式字符串发送到数据库之前,将你的格式字符串传递给ToString
。当然,如果您使用的是 EF 之类的工具,那么转换已经为您完成,这无关紧要。
示例:
string myFormattedDateTime = dbDate.ToString("yyyy-MM-dd HH:mm:ss");
仔细阅读您的问题,我意识到您似乎认为 DateTime 具有某种 "stored" 格式。它不是。 DateTime 只是一个数字集合,其中包含表示日期和时间所需的信息。您描述的格式仅存在于字符串表示中。