DevExpress XtraTreeList 列排序数值
DevExpress XtraTreeList Columns Sorting Numerical
我有一个奇怪的问题,我不确定如何解决。主要是看不出自己做错了什么。
我正在使用 DevExpress TreeList 控件。我有多个列,主要问题是按数字对列进行排序时,列按字母顺序排序,例如:
56.2, 57.3, 63.4, 78.9... then 8.3.
所以它是按字母顺序排序的。我已经多次将 UnboundType
设置为 Decimal
,并将 SortMode
更改为 Value
,并且我尝试了 Default
。我也试过将 UnboundType
更改为 Object
。我也试过将 FormatMode
更改为 Numeric
,但仍然会发生这种情况。我确实在 DX 上找到了 post,但它没有用,与我的情况无关。
有人可以帮忙吗?有没有人遇到过这个问题?如果您有任何想法,我将不胜感激。
提前致谢!
感谢马可的回复。我已经阅读了该知识库文章,我尝试使用以下事件处理程序设置 SortMode: Custom
:
private void trResults_CompareNodeValues(object sender, DevExpress.XtraTreeList.CompareNodeValuesEventArgs e)
{
if (e.Column == colSize)
{
try
{
int value1 = Convert.ToInt32(Regex.Replace((e.NodeValue1 as string), "[^0-9.]", ""));
int value2 = Convert.ToInt32(Regex.Replace((e.NodeValue2 as string), "[^0-9.]", ""));
e.Result = value1 - value2;
}
catch { }
}
}
我已经按照您的方式和我的 RegEx 进行了尝试(应该没有任何效果)。这就是情况变得更糟的地方;我已经设置了一个断点,你猜怎么着,当我对列进行排序时,它没有命中?!
这到底是怎么回事!?
提前致谢。
您需要处理事件 CompareNodeValues (Example on DevExpress site)
private void mytree_CompareNodeValues(object sender,DevExpress.XtraTreeList.CompareNodeValuesEventArgs e) {
if (e.Column == myspecialsortcolumn) {
e.Result = Convert.ToDecimal(e.NodeValue1) - Convert.ToDecimal(e.NodeValue2);
}
}
都是好人。我犯了一个小错误,原来我没有将 even 连接到 TreeList,被我自己的白痴所挫败。
我有一个奇怪的问题,我不确定如何解决。主要是看不出自己做错了什么。
我正在使用 DevExpress TreeList 控件。我有多个列,主要问题是按数字对列进行排序时,列按字母顺序排序,例如:
56.2, 57.3, 63.4, 78.9... then 8.3.
所以它是按字母顺序排序的。我已经多次将 UnboundType
设置为 Decimal
,并将 SortMode
更改为 Value
,并且我尝试了 Default
。我也试过将 UnboundType
更改为 Object
。我也试过将 FormatMode
更改为 Numeric
,但仍然会发生这种情况。我确实在 DX 上找到了 post,但它没有用,与我的情况无关。
有人可以帮忙吗?有没有人遇到过这个问题?如果您有任何想法,我将不胜感激。
提前致谢!
感谢马可的回复。我已经阅读了该知识库文章,我尝试使用以下事件处理程序设置 SortMode: Custom
:
private void trResults_CompareNodeValues(object sender, DevExpress.XtraTreeList.CompareNodeValuesEventArgs e)
{
if (e.Column == colSize)
{
try
{
int value1 = Convert.ToInt32(Regex.Replace((e.NodeValue1 as string), "[^0-9.]", ""));
int value2 = Convert.ToInt32(Regex.Replace((e.NodeValue2 as string), "[^0-9.]", ""));
e.Result = value1 - value2;
}
catch { }
}
}
我已经按照您的方式和我的 RegEx 进行了尝试(应该没有任何效果)。这就是情况变得更糟的地方;我已经设置了一个断点,你猜怎么着,当我对列进行排序时,它没有命中?!
这到底是怎么回事!?
提前致谢。
您需要处理事件 CompareNodeValues (Example on DevExpress site)
private void mytree_CompareNodeValues(object sender,DevExpress.XtraTreeList.CompareNodeValuesEventArgs e) {
if (e.Column == myspecialsortcolumn) {
e.Result = Convert.ToDecimal(e.NodeValue1) - Convert.ToDecimal(e.NodeValue2);
}
}
都是好人。我犯了一个小错误,原来我没有将 even 连接到 TreeList,被我自己的白痴所挫败。