![](/img/trans.png)
[英]The given value of type String from the data source cannot be converted to type int of the specified target column.'
[英]Sorting a converted String to DateTime column.
我的DataTable有一个Date列,该列必须接受几种不同的DateTime格式。 我想将这些合并为一种形式,然后按日期进行相应排序。
到目前为止,我已经编写了以下代码来更改日期的显示方式。 但是它仍然不能正确排序。 显示的内容不是排序时使用的内容。 它仍然使用旧格式。
因此2018-05-30仍会在2018-09-05之后,因为系统正在读取数据,然后将其转换为30/05/2018和05/09/2018。 并且由于30> 05,因此排序不正确。 有人有什么建议吗?
if (e.PropertyName.Contains("Date"))
{
DataGridTextColumn dgtc = e.Column as DataGridTextColumn;
DateTimeConverter con = new DateTimeConverter();
(dgtc.Binding as Binding).Converter = con;
}
public class DateTimeConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value != null)
{
try
{
return DateTime.Parse(value.ToString()).ToString("yyyy-MM-dd");
}
catch
{
return value;
}
}
return value;
}
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value != null && value.GetType() == typeof(System.DateTime))
{
DateTime t = (DateTime)value;
return t.ToShortDateString();
}
return value;
}
}
你有没有尝试过
List<DateTime> yourdateTime = new List<DateTime>();
yourdateTime.OrderBy(x => x.Date);
也看
yourdateTime.OrderBy(x => x.Date.TimeOfDay)
.ThenBy(x => x.Date.Date)
.ThenBy(x => x.Date.Year);
进入Date Class
您可以通过多种方式对其进行排序。 只需确保是否使用多个来先使用OrderBy
,然后再使用ThenBy
进行后续ThenBy
。
如果您的日期列/属性被调用,则将DataGridColumn
的SortMemberPath
属性设置为“ Date”。 然后,无论格式如何,都应按此属性对列进行排序。
但是您不需要使用转换器来格式化日期。 您可以只设置绑定的StringFormat
属性:
if (e.PropertyName.Contains("Date"))
{
DataGridTextColumn dgtc = e.Column as DataGridTextColumn;
dgtc.Binding = new Binding(e.PropertyName) { StringFormat = "yyyy-MM-dd" };
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.