编程语言
首页 > 编程语言> > 首页> C#> DateTime.ParseExact没有做我想做的事

首页> C#> DateTime.ParseExact没有做我想做的事

作者:互联网

当对日期时间使用.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仅表示输入必须与给定格式匹配才能使用(并且不会引发异常).它与Parse相对,它将接受任何有效的Date / Time格式.它与它创建的DateTime对象的任何字符串表示形式的将来格式完全没有关系.

如果要以给定的格式输出,请将格式字符串传递给ToString,然后再将该字符串发送到数据库.当然,如果您使用的是类似EF的工具,则转换已为您完成,没关系.

例:

string myFormattedDateTime = dbDate.ToString("yyyy-MM-dd HH:mm:ss");

仔细阅读您的问题,我意识到您似乎认为DateTime具有某种“存储”格式.它不是. DateTime只是数字的集合,其中包含代表日期和时间所需的信息.您描述的格式仅以字符串表示形式存在.

标签:datetime-format,datetime,c
来源: https://codeday.me/bug/20191111/2020545.html