C#中查看xml某个节点是否存在..........................新手求解

hellenren12345 2012-10-14 08:49:54
<?xml version="1.0" encoding="utf-8" ?>
<root>
<left>
<div1></div1>
</left>
<center>

</center>
<right>

</right>
</root>

public static bool isSelectNode(string xmlpath,string node)
{
....

if(存在)
{
return true;
}
else
{
return false;
}
}

isSelectNode(xxx.xml,"div1");

新手求解,请给出代码。谢谢!
...全文
1030 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
hellenren12345 2012-10-14
  • 打赏
  • 举报
回复
2楼正解,谢谢!!!
dalmeeme 2012-10-14
  • 打赏
  • 举报
回复
也可以用Dom:
	public static bool IsSelectNode(string xmlPath, string node)
{
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(xmlPath);
XmlNode result = xmlDoc.SelectSingleNode(@"//" + node);
return result != null;
}
dalmeeme 2012-10-14
  • 打赏
  • 举报
回复
	public static bool IsSelectNode(string xmlPath, string node)
{
using (XmlReader reader = XmlReader.Create(xmlPath))
{
while (reader.Read())
{
if (reader.Name == node && reader.NodeType == XmlNodeType.Element)
return true;
}
}
return false;
}

调用:Console.Write(IsSelectNode(@"c:\test.xml","div1"));
hellenren12345 2012-10-14
  • 打赏
  • 举报
回复
<?xml version="1.0" encoding="utf-8" ?>
<root>
<left>
<div1></div1>
</left>
<center>

</center>
<right>

</right>
</root>

div1节点 可能在left 可能在center 也可能在right
怎么才能根据root 遍历下面所有的子节点以及子子节点是否存在<div1>这个节点,急急..... 求解
自己写的C#常用类库,使用时请先添加引用:UsrCustomFun.dll、DevComponents.DotNetBar2.dll,压缩包内的其他文件请与UsrCustomFun.dll放置同一目录,然后在程序引用命名空间:using UsrCustomFun;包括: 1.自定义MessageBox,消息内容与错误代码分开,使用了6个重载方式。调用方法例子: UserMessageBox.UsrShow("执行SQL查询出错!", "数据库错误", ec.Message.ToString()); 2.等待提示窗口,使用了3个重载方法。 打开:UserWaitBox.UsrShow("等待信息"); 关闭:UserWaitBox.UsrClose(); 3.打印DataGridView,使用了9个重载方式,可自定义标题与打印样式: DataGridViewPrint.PrintDgv(dataGridView); 4.DataTable导出为Excel,3个重载方式: DataTableToExcel.DtToExcel(DataTable); 5.DataTable生成Pdf文件,6个重载方式: UsrExport.ExPdf(dataTable); 6.XML文件操作,可根据XML文件节点、路径来读取、修改、写入XML: UserXml.ReadXml(string XML的路径); UserXml.ReadXmlElement(string XML的路径,节点名称); UserXml.WriteXmlElement(XML路径,节点名称,内容); 7.数据库操作,目前有Access、SqlServer、Oracel (7.1)先配置数据库连接字符串: UsrCustomFun.SqlConn.SqlParameters下根据数据库类型返回一个数据库连接字符串。 (7.2)再执行数据库操作: (7.2.1)UsrCustomFun.SqlConn.SqlConnAccess下为Access的数据库操作,可根据SQL返回int型、string型、DataTable、DataReader、DataSet及无返回操作。 (7.2.2)UsrCustomFun.SqlConn.SqlConnOracle,操作类型同7.2.1 (7.2.3)UsrCustomFun.SqlConn.SqlConnSqlServer,操作类型同7.2.1

110,545

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧