【转】为 XmlNode.SelectNodes 加上排序功能
测试资料:
<Config>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='' b='' c='' m=''/>
<Item a='A' b='' c='' m=''/>
</Config>
测试结果:
1. 依 c 及 b 属性排序
2. b 属性改由大到小排序
c,b
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a=A b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m= c,-b
a=A b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
a= b= c= m=
测试程序:
static void Main(string[] args)
{
var xml = new XmlDocument();
xml.LoadXml(@"<Config>
<Item a='1' b='5' c='9' m='9'/>
<Item a='2' b='6' c='9' m='9'/>
<Item a='3' b='7' c='9' m='9'/>
<Item a='4' b='8' c='9' m='1'/>
<Item a='5' b='9' c='9' m='1'/>
<Item a='6' b='0' c='5' m='1'/>
<Item a='7' b='1' c='5' m='1'/>
<Item a='8' b='2' c='5' m='5'/>
<Item a='9' b='3' c='5' m='5'/>
<Item a='0' b='4' c='5' m='5'/>
<Item a='A' b='5' c='5' m='5'/>
</Config>"); var keepRunning = true;
while (keepRunning)
{
var command = Console.ReadLine();
switch (command)
{
case "/exit":
case "/quit":
keepRunning = false;
break;
default:
try
{
foreach (var i in xml.SelectNodes("/Config/Item", command))
{
foreach (XmlAttribute a in i.Attributes)
Console.Write("{0}={1} ", a.Name, a.Value);
Console.WriteLine();
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
break;
}
}
}
核心程序:
public static class XmlSorter
{
public static IEnumerable<XmlNode> SelectNodes(this XmlNode node, string xpath, string orderby)
{
var sorter = Sorter.Create(orderby);
return
sorter == null
? node.SelectNodes(xpath).AsEnumerable()
: sorter.Sort(node.SelectNodes(xpath));
}
private static IEnumerable<XmlNode> AsEnumerable(this XmlNodeList list)
{
foreach (XmlNode i in list)
yield return i;
}
private static string Attrib(this XmlNode node, string name, string defaultValue)
{
return (node.Attributes[name] == null)
? defaultValue
: node.Attributes[name].Value;
}
class Sorter
{
public string Key { get; set; }
public bool Descending { get; set; }
public Sorter Next { get; set; }
private IOrderedEnumerable<XmlNode> Sort(IOrderedEnumerable<XmlNode> list)
{
var flow = (Next != null ? 0x10 : 0x00) + (Descending ? 0x01 : 0x00);
switch (flow)
{
case 0x11: return Next.Sort(list.ThenByDescending(o => o.Attrib(Key, "")));
case 0x10: return Next.Sort(list.ThenBy(o => o.Attrib(Key, "")));
case 0x01: return list.ThenByDescending(o => o.Attrib(Key, ""));
case 0x00: return list.ThenBy(o => o.Attrib(Key, ""));
}
throw new Exception("!!!");
}
public IEnumerable<XmlNode> Sort(XmlNodeList nodes)
{
var flow = (Next != null ? 0x10 : 0x00) + (Descending ? 0x01 : 0x00);
switch (flow)
{
case 0x11: return Next.Sort(nodes.AsEnumerable().OrderByDescending(o => o.Attrib(Key, "")));
case 0x10: return Next.Sort(nodes.AsEnumerable().OrderBy(o => o.Attrib(Key, "")));
case 0x01: return nodes.AsEnumerable().OrderByDescending(o => o.Attrib(Key, ""));
case 0x00: return nodes.AsEnumerable().OrderBy(o => o.Attrib(Key, ""));
}
return null;
}
public static Sorter Create(string orderby)
{
if (string.IsNullOrEmpty(orderby)) return null;
var fields = orderby.Split(',');
var list = new List<Sorter>();
foreach (var i in fields)
{
var s = i.Trim();
var desc = s.StartsWith("-");
var key = desc ? s.Substring() : s;
if (string.IsNullOrEmpty(key)) continue;
list.Add(new Sorter { Key = key, Descending = desc });
}
for (int i = ; i < list.Count; i++)
list[i - ].Next = list[i];
if (list.Count > ) return list[];
return null;
}
}
}
原谅链接:http://www.dotblogs.com.tw/cihsieh/archive/2013/11/26/131445.aspx
【转】为 XmlNode.SelectNodes 加上排序功能的更多相关文章
- redis(四)--简单实现Redis缓存中的排序功能
在实现缓存排序功能之前,必须先明白这一功能的合理性.不妨思考一下,既然可以在数据库中排序,为什么还要把排序功能放在缓存中实现呢?这里简单总结了两个原因:首先,排序会增加数据库的负载,难以支撑高并发的应 ...
- 禁用datagridview中的自动排序功能
把datagridview中的自动排序功能禁用自己收集的两种方法,看看吧①DataGridView中的Columns属性里面可以设置.进入"EditColumns"窗口后,在相应的 ...
- ListBox实现拖拽排序功能
1.拖拽需要实现的事件包括: PreviewMouseLeftButtonDown LBoxSort_OnDrop 具体实现如下: private void LBoxSort_OnPreviewMou ...
- 简单实现Redis缓存中的排序功能
1.在实现缓存排序功能之前,必须先明白这一功能的合理性.不妨思考一下,既然可以在数据库中排序,为什么还要把排序功能放在缓存中实现呢?这里简单总结了两个原因:首先,排序会增加数据库的负载,难以支撑高并发 ...
- Java实现中文字符串的排序功能
package test; /** * * @Title 书的信息类 * @author LR * @version 1.0 * @since 2016-04-21 */ public class B ...
- MYSQL-实现ORACLE- row_number() over(partition by ) 分组排序功能
MYSQL-实现ORACLE- row_number() over(partition by ) 分组排序功能 由于MYSQL没有提供类似ORACLE中OVER()这样丰富的分析函数. 所以在MYSQ ...
- nls_sort和nlssort 排序功能介绍
nls_sort和nlssort 排序功能介绍 博客分类: oracle ALTER SESSION SET NLS_SORT=''; 排序影响整个会话 Oracle9i之前,中文是按照二进制编码 ...
- [WPF]ListView点击列头排序功能实现
[转] [WPF]ListView点击列头排序功能实现 这是一个非常常见的功能,要求也很简单,在Column Header上显示一个小三角表示表示现在是在哪个Header上的正序还是倒序就可以了. ...
- MVC5 Entity Framework学习参加排序、筛选和排序功能
上一篇文章实现Student 基本的实体CRUD操作.本文将展示如何Students Index页添加排序.筛选和分页功能. 以下是排序完成时.经过筛选和分页功能截图,您可以在列标题点击排序. 1.为 ...
随机推荐
- Python 同时for遍历多个列表
a = range(3) b = range(3) [ (x, y) for x, y in zip(a, b) ] 结果: [ (0,0), (1,1), (2,2) ] 当然,如上可以推广到多个列 ...
- 【暑假】[实用数据结构]UVAlive 3942 Remember the Word
UVAlive 3942 Remember the Word 题目: Remember the Word Time Limit: 3000MS Memory Limit: Unknown ...
- 命令rm
mv -r 递归删除文件夹内所有东西mv -i 交互式删除mv -f 强制删除,没有警告提示
- 50道经典的JAVA编程题(21-25)
50道经典的JAVA编程题(21-25),明天早上java考试了,还是坚持做题吧...这题比老师的题好多了! [程序21]TestJieCheng.java题目:求1+2!+3!+...+20!的和1 ...
- HW6.6
public class Solution { public static void main(String[] args) { int[] prime = new int[50]; prime[0] ...
- Java管道流PipedStream
管道读取流和管道写入流可以像管道一样对接上,管道读取流就可以读取管道写入流写入的数据.需要注意的是需要加入多线程技术,因为单线程,先执行read,会发生死锁,因为read方法是阻塞式的,没有数据的re ...
- 函数 stat() 详解
先看看MSDN的解釋: stat(): Get status information on a file. Parameters: path: pointer to a string con ...
- hdu2545 树上战争 (并查集)
Problem Description 给一棵树,如果树上的某个节点被某个人占据,则它的所有儿子都被占据,lxh和pfz初始时分别站在两个节点上,谁当前所在的点被另一个人占据,他就输了比赛,问谁能获胜 ...
- 重看Decorator Pattern,联想到Delegate传递及Flags Enum--欢迎拍砖!
话说装饰模式(Decorator)的动机是“动态地给一个对象添加一些额外的职责.就增加功能来说,Decorator模式相比生成子类更为灵活.[GOF <设计模式>]”.再次学到该模式,有感 ...
- android系统自带图标集合(android.R.drawable查看)
alert_dark_frame alert_light_frame arrow_down_float arrow_up_float bottom_bar btn_default btn_defaul ...