c# - DateTime.ParseExact 没有按照我的意愿去做

标签 c# datetime datetime-format

当对 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 格式存储在数据库中,例如“年-月-日时:分:秒”。但无论出于何种原因,ParseExact 似乎不适用于我的情况。我得到的日期时间格式是“dd-MM-yyyy HH:mm”。

最佳答案

它不会执行您想要的操作,因为该函数不应该执行您所描述的操作。

ParseExact 只是表示输入 必须匹配给定的格式才能使用(并且不会抛出异常)。它是 Parse 的对应物,它将接受任何有效的日期/时间格式。 它绝对不会影响它创建的 DateTime 对象的任何字符串表示形式的 future 格式。

如果您想以给定的格式输出,请在将格式字符串发送到数据库之前将格式字符串传递给ToString。当然,如果您使用的是 EF 之类的工具,那么转换会为您完成,这无关紧要。

例子:

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

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

关于c# - DateTime.ParseExact 没有按照我的意愿去做,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43150710/

相关文章:

javascript - 如何根据日期和时间创建时间戳

iis-7 - IIS 7 服务器中的日期时间格式问题

mysql - TIMEDIFF 的格式结果以天为单位 :hours:min:sec

c# - 来自 SelectionChanged 事件 WinRT 的 ArgumentOutOfRangeException

c# - 无副作用二传手的方法

c# - ConcurrentDictionary 枚举和锁定

python - 为什么 date + timedelta 变成日期,而不是日期时间?

c# - 将 System.Array 的 C# 十进制值转换为字符串

C++ mktime 返回随机日期

Python 3 : Convert decimals to date time