首页> 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