我来自印度,这里我们遵循dd-mm-yyyy的日期格式。
我的问题是,我们的各种客户需要他们的日期时间以上述格式显示。但是我们使用的SQL Server作为后端,并不将dd识别为有效的日期时间格式。我们通常做的是使用CultureInfo将给定的日期转换为mm-dd-yyyy,或者使用Convert.ToDateTime() or DateTime.Parse or DateTime.TryParse()。
另外,我遇到了另一种情况,当我的输入日期是正确的格式时,比如MM-dd-yyyy or MM/dd/yyyy or yyyy-MM-dd,但是我的本地系统日期不是上面提到的,然后是it throws exception, input string in not in correct format。我想不出如何自动解决这个问题。
Exisitng自定义方法:但是在大多数情况下,这种方法失败的次数最多。
/// <summary>
/// Parses string value from a supplied value to DateTime.
/// Usage: var i = Common.ParseDate(yourDateString);
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
private static DateTime ParseDate(string value)
{
DateTime i;
if (!DateTime.TryParse(value, out i))
return Convert.ToDateTime("01/01/1700",CultureInfo.InvariantCulture);
// Assuming 01/01/1700 as default value instead of null.
return i;
}请修改以上内容,这样,我的方法将自动将任何日期时间转换为与Server兼容的格式,如yyyy。
用法应该如下所示:
Input:
DateTime dt = DateTimeParser("29-12-2013"); // in case or double figure months and dates
Output of dt: either 2013-12-29 or 12/29/2013
DateTime dt = DateTimeParser("9-2-2013"); // in case or single figure months and dates
Output of dt: either 2013-2-9 or 2/9/2013 (sql-server compatible)请注意:日期时间转换应该与系统时钟无关。
提前感谢
发布于 2014-01-29 02:58:23
我有过一次完全想要的东西,尽管我们可以假设用户的意思,因为正确性并不重要(因为在输入文本日期时间时,就像MS一样)。
实际上,您可以从内置的区域性中收集所有可能的日期-时间格式,以及许多您可以定义自己的自定义格式。我曾经想要一个非常全面的日期时间格式匹配。
我做了一些与纳法尔的回答非常相似的事情。这里有一个解决方案,将他的答案与我的一套大格式结合起来:
static string[] GetDateTimeFormats()
{
var defaultFormats = CultureInfo.GetCultures(CultureTypes.AllCultures)
.SelectMany(x => x.DateTimeFormat.GetAllDateTimePatterns())
.Distinct(); //to speed up things
//discard some formats that're not worthy of consideration
var goodDefaultFormats = defaultFormats.Where(x => !IsPoorFormat(x) && !IsConflictingFormat(x));
var customFormats = GetCustomDateTimeFormats();
var allFormats = goodDefaultFormats.Concat(customFormats).ToArray();
//a technique to get comma separated time formats,
//for eg, from dd-MM-yyyy h:mm:ss tt we get -> dd-MM-yyyy, h:mm:ss tt
var moreCustomFormats = allFormats.Select(f => new
{
f,
i = f.IndexOf(" h", StringComparison.OrdinalIgnoreCase)
})
.Where(x => x.i >= 0)
.Select(x => new { x.f, c = x.f[x.i - 1], x.i })
.Where(x => !char.IsPunctuation(x.c) && x.c != 't')
.Select(x => x.f.Insert(x.i, ","));
allFormats = allFormats.Union(moreCustomFormats).ToArray(); //Union removes duplicates
return allFormats;
}
static bool IsPoorFormat(string format)
{
//all discardable formats in case any
string[] ignorables = { "HH", "MMMM yyyy", "MMMM, yyyy", "yyyy MMMM", "yyyy.M", "yyyy-MM",
"MMMM,yy", "MMMM, yy", "MMMM,yyyy", "MMMM, yyyy", "yyyy. MMMM" };
return ignorables.Contains(format);
}
//to remove conflicting date formats, for example,
//formats like MM-dd-yy, yy-MM-dd, dd-MM-yy etc can be conflicting
static bool IsConflictingFormat(string format)
{
//in this example we discard formats like M-d-yy, yy-MM-dd etc, but keep dd-MM-yy
//in case you want to keep MM-dd-yy, the placeholders array should be { 'd', 'y' },
//and similarly if the preferred format is yy-MM-dd, array should be { 'M', 'd' }
var placeholders = new[] { 'M', 'y' };
var separators = new[] { ' ', '.', '-', '/' };
var patterns = placeholders.Select(x => x.ToString())
.SelectMany(x => new[] { x, x + x })
.SelectMany(x => separators, (x, y) => x + y);
return patterns.Any(format.StartsWith);
}
static string[] GetCustomDateTimeFormats()
{
return new[]
{
"dddd, MMMM d, yyyy h:mm:ss tt",
"dddd, MMMM d, yyyy H:mm:ss",
"dddd, MMMM d, yyyy h:mm tt",
"dddd, MMMM d, yyyy H:mm",
"dddd, MMM d, yyyy h:mm:ss tt",
"dddd, MMM d, yyyy H:mm:ss",
"dddd, MMM d, yyyy h:mm tt",
"dddd, MMM d, yyyy H:mm",
"ddd, MMMM d, yyyy h:mm:ss tt",
"ddd, MMMM d, yyyy H:mm:ss",
"ddd, MMMM d, yyyy h:mm tt",
"ddd, MMMM d, yyyy H:mm",
"ddd, MMM d, yyyy h:mm:ss tt",
"ddd, MMM d, yyyy H:mm:ss",
"ddd, MMM d, yyyy h:mm tt",
"ddd, MMM d, yyyy H:mm",
"dddd, MMMM d yyyy h:mm:ss tt",
"dddd, MMMM d yyyy H:mm:ss",
"dddd, MMMM d yyyy h:mm tt",
"dddd, MMMM d yyyy H:mm",
"dddd, MMM d yyyy h:mm:ss tt",
"dddd, MMM d yyyy H:mm:ss",
"dddd, MMM d yyyy h:mm tt",
"dddd, MMM d yyyy H:mm",
"ddd, MMMM d yyyy h:mm:ss tt",
"ddd, MMMM d yyyy H:mm:ss",
"ddd, MMMM d yyyy h:mm tt",
"ddd, MMMM d yyyy H:mm",
"ddd, MMM d yyyy h:mm:ss tt",
"ddd, MMM d yyyy H:mm:ss",
"ddd, MMM d yyyy h:mm tt",
"ddd, MMM d yyyy H:mm",
///////////////////////////
"dddd, d MMMM, yyyy h:mm:ss tt",
"dddd, d MMMM, yyyy H:mm:ss",
"dddd, d MMMM, yyyy h:mm tt",
"dddd, d MMMM, yyyy H:mm",
"dddd, d MMM, yyyy h:mm:ss tt",
"dddd, d MMM, yyyy H:mm:ss",
"dddd, d MMM, yyyy h:mm tt",
"dddd, d MMM, yyyy H:mm",
"ddd, d MMMM, yyyy h:mm:ss tt",
"ddd, d MMMM, yyyy H:mm:ss",
"ddd, d MMMM, yyyy h:mm tt",
"ddd, d MMMM, yyyy H:mm",
"ddd, d MMM, yyyy h:mm:ss tt",
"ddd, d MMM, yyyy H:mm:ss",
"ddd, d MMM, yyyy h:mm tt",
"ddd, d MMM, yyyy H:mm",
"dddd, d MMMM yyyy h:mm:ss tt",
"dddd, d MMMM yyyy H:mm:ss",
"dddd, d MMMM yyyy h:mm tt",
"dddd, d MMMM yyyy H:mm",
"dddd, d MMM yyyy h:mm:ss tt",
"dddd, d MMM yyyy H:mm:ss",
"dddd, d MMM yyyy h:mm tt",
"dddd, d MMM yyyy H:mm",
"ddd, d MMMM yyyy h:mm:ss tt",
"ddd, d MMMM yyyy H:mm:ss",
"ddd, d MMMM yyyy h:mm tt",
"ddd, d MMMM yyyy H:mm",
"ddd, d MMM yyyy h:mm:ss tt",
"ddd, d MMM yyyy H:mm:ss",
"ddd, d MMM yyyy h:mm tt",
"ddd, d MMM yyyy H:mm",
/////////////////////////////////
"yyyy, MMMM d h:mm:ss tt",
"yyyy, MMMM d H:mm:ss",
"yyyy, MMMM d h:mm tt",
"yyyy, MMMM d H:mm",
"yyyy, MMM d h:mm:ss tt",
"yyyy, MMM d H:mm:ss",
"yyyy, MMM d h:mm tt",
"yyyy, MMM d H:mm",
"yyyy, MM d h:mm:ss tt",
"yyyy, MM d H:mm:ss",
"yyyy, MM d h:mm tt",
"yyyy, MM d H:mm",
"yyyy MMMM d h:mm:ss tt",
"yyyy MMMM d H:mm:ss",
"yyyy MMMM d h:mm tt",
"yyyy MMMM d H:mm",
"yyyy MMM d h:mm:ss tt",
"yyyy MMM d H:mm:ss",
"yyyy MMM d h:mm tt",
"yyyy MMM d H:mm",
"yyyy MM d h:mm:ss tt",
"yyyy MM d H:mm:ss",
"yyyy MM d h:mm tt",
"yyyy MM d H:mm",
///////////////////////
"yyyy, d MMMM h:mm:ss tt",
"yyyy, d MMMM H:mm:ss",
"yyyy, d MMMM h:mm tt",
"yyyy, d MMMM H:mm",
"yyyy, d MMM h:mm:ss tt",
"yyyy, d MMM H:mm:ss",
"yyyy, d MMM h:mm tt",
"yyyy, d MMM H:mm",
"yyyy, d MM h:mm:ss tt",
"yyyy, d MM H:mm:ss",
"yyyy, d MM h:mm tt",
"yyyy, d MM H:mm",
"yyyy d MMMM h:mm:ss tt",
"yyyy d MMMM H:mm:ss",
"yyyy d MMMM h:mm tt",
"yyyy d MMMM H:mm",
"yyyy d MMM h:mm:ss tt",
"yyyy d MMM H:mm:ss",
"yyyy d MMM h:mm tt",
"yyyy d MMM H:mm",
"yyyy d MM h:mm:ss tt",
"yyyy d MM H:mm:ss",
"yyyy d MM h:mm tt",
"yyyy d MM H:mm",
////////////////////////////////
"MMMM d, yyyy h:mm:ss tt",
"MMMM d, yyyy H:mm:ss",
"MMMM d, yyyy h:mm tt",
"MMMM d, yyyy H:mm",
"MMM d, yyyy h:mm:ss tt",
"MMM d, yyyy H:mm:ss",
"MMM d, yyyy h:mm tt",
"MMM d, yyyy H:mm",
"MMMM d yyyy h:mm:ss tt",
"MMMM d yyyy H:mm:ss",
"MMMM d yyyy h:mm tt",
"MMMM d yyyy H:mm",
"MMM d yyyy h:mm:ss tt",
"MMM d yyyy H:mm:ss",
"MMM d yyyy h:mm tt",
"MMM d yyyy H:mm",
////////////////////////////////////
"d MMMM, yyyy h:mm:ss tt",
"d MMMM, yyyy H:mm:ss",
"d MMMM, yyyy h:mm tt",
"d MMMM, yyyy H:mm",
"d MMM, yyyy h:mm:ss tt",
"d MMM, yyyy H:mm:ss",
"d MMM, yyyy h:mm tt",
"d MMM, yyyy H:mm",
"d MMMM yyyy h:mm:ss tt",
"d MMMM yyyy H:mm:ss",
"d MMMM yyyy h:mm tt",
"d MMMM yyyy H:mm",
"d MMM yyyy h:mm:ss tt",
"d MMM yyyy H:mm:ss",
"d MMM yyyy h:mm tt",
"d MMM yyyy H:mm",
/////////////////////////
"dddd, MMMM d, yyyy",
"dddd, MMM d, yyyy",
"ddd, MMMM d, yyyy",
"ddd, MMM d, yyyy",
"dddd, MMMM d yyyy",
"dddd, MMM d yyyy",
"ddd, MMMM d yyyy",
"ddd, MMM d yyyy",
//////////////////////////
"dddd, d MMMM, yyyy",
"dddd, d MMM, yyyy",
"ddd, d MMMM, yyyy",
"ddd, d MMM, yyyy",
"dddd, d MMMM yyyy",
"dddd, d MMM yyyy",
"ddd, d MMMM yyyy",
"ddd, d MMM yyyy",
///////////////////////////
"MMMM d, yyyy",
"MMM d, yyyy",
"MMMM d yyyy",
"MMM d yyyy",
//////////////////////////
"d MMMM, yyyy",
"d MMM, yyyy",
"d MMMM yyyy",
"d MMM yyyy",
//////////////////////////
"yyyy, MMMM d",
"yyyy, MMM d",
"yyyy MMMM d",
"yyyy MMM d",
//////////////////////////
"yyyy d MMMM",
"yyyy d MMM",
"yyyy, d MMMM",
"yyyy, d MMM",
///////////////////////////
"d MMMM",
"d MMM",
/////////////////////////////
"MMMM d",
"MMM d",
////////////////////////////
"dd",
};
}发布于 2013-04-25 10:00:52
您不需要将日期解析为格式。对于字段使用Server中的DateTime数据类型,该字段与格式不同。还请确保在通过SqlParameter与Server交互时使用C#。DateTime格式只应用于显示日期。比如:
using(SqlConnection conn = new SqlConnection("connectionstring"))
using (SqlCommand cmd = new SqlCommand())
{
cmd.CommandText = "Insert into yourtable(datecolumn) VALUES (@pDate);";
cmd.Parameters.AddWithValue("@pDate", DateTime.Now);
cmd.Connection = conn;
//.....
}发布于 2013-04-25 10:02:25
就个人而言,我使用参数。否则,您可以在Server中强制使用特定的DateTime格式。
https://stackoverflow.com/questions/16211765
复制相似问题