有人如何验证XML文件中是否存在特定元素?假设我有一个不断变化的XML文件,我需要在读取/解析它之前验证每个元素是否存在。
答案 0 :(得分:52)
if(doc.SelectSingleNode("//mynode")==null)....
应该这样做(显然doc是你的XmlDocument对象)
或者,您可以使用XSD并对其进行验证
答案 1 :(得分:4)
不确定您想要做什么,但使用DTD或架构可能只需要验证 xml。
否则,如果您想查找元素,可以使用xpath查询来搜索特定元素。
答案 2 :(得分:4)
您可以遍历每个节点并查看节点是否存在。
doc.Load(xmlPath);
XmlNodeList node = doc.SelectNodes("//Nodes/Node");
foreach (XmlNode chNode in node)
{
try{
if (chNode["innerNode"]==null)
return true; //node exists
//if ... check for any other nodes you need to
}catch(Exception e){return false; //some node doesn't exists.}
}
您遍历节点下的每个Node元素(比如这是root)并检查是否存在名为'innerNode'的节点(如果需要,添加其他节点)。 try..catch是因为我怀疑如果节点不存在,这会引发流行的'对象引用未设置'错误。
答案 3 :(得分:4)
尝试这个怎么样:
using (XmlTextReader reader = new XmlTextReader(xmlPath))
{
while (reader.Read())
{
if (reader.NodeType == XmlNodeType.Element)
{
//do your code here
}
}
}
答案 4 :(得分:4)
//如果问题是“只是”在您之前验证该元素是否存在于xml文件中 //提取你可以做的值
XmlNodeList YOURTEMPVARIABLE = doc.GetElementsByTagName("YOUR_ELEMENTNAME");
if (YOURTEMPVARIABLE.Count > 0 )
{
doctype = YOURTEMPVARIABLE[0].InnerXml;
}
else
{
doctype = "";
}
答案 5 :(得分:2)
另外还有sangam
代码
if (chNode["innerNode"]["innermostNode"]==null)
return true; //node *parentNode*/innerNode/innermostNode exists
答案 6 :(得分:1)
答案 7 :(得分:0)
以下是一个简单的函数,用于检查xml文件中是否存在特定节点。
public boolean envParamExists(String xmlFilePath, String paramName){
try{
Document doc = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(new File(xmlFilePath));
doc.getDocumentElement().normalize();
if(doc.getElementsByTagName(paramName).getLength()>0)
return true;
else
return false;
}catch (Exception e) {
//error handling
}
return false;
}
答案 8 :(得分:0)
有点晚了,但如果有帮助,这对我有用......
XmlNodeList NodoEstudios = DocumentoXML.SelectNodes("//ALUMNOS/ALUMNO[@id=\"" + Id + "\"]/estudios");
string Proyecto = "";
foreach(XmlElement ElementoProyecto in NodoEstudios)
{
XmlNodeList EleProyecto = ElementoProyecto.GetElementsByTagName("proyecto");
Proyecto = (EleProyecto[0] == null)?"": EleProyecto[0].InnerText;
}
答案 9 :(得分:0)
//使用XmlReader检查xml元素值是否存在
using (XmlReader xmlReader = XmlReader.Create(new StringReader("XMLSTRING")))
{
if (xmlReader.ReadToFollowing("XMLNODE"))
{
string nodeValue = xmlReader.ReadElementString("XMLNODE");
}
}
答案 10 :(得分:0)
遇到了同样的问题,使用 SelectSingleNode 的 null-coalescing运算符进行了处理,将string.Empty分配为null
foreach (XmlNode txElement in txElements)
{
var txStatus = txElement.SelectSingleNode(".//ns:TxSts", nsmgr).InnerText ?? string.Empty;
var endToEndId = txElement.SelectSingleNode(".//ns:OrgnlEndToEndId", nsmgr).InnerText ?? string.Empty;
var paymentAmount = txElement.SelectSingleNode(".//ns:InstdAmt", nsmgr).InnerText ?? string.Empty;
var paymentAmountCcy = txElement.SelectSingleNode(".//ns:InstdAmt", nsmgr).Attributes["Ccy"].Value ?? string.Empty;
var clientId = txElement.SelectSingleNode(".//ns:OrgnlEndToEndId", nsmgr).InnerText ?? string.Empty;
var bankSortCode = txElement.SelectSingleNode(".//ns:OrgnlEndToEndId", nsmgr).InnerText ?? string.Empty;
//TODO finish Object creation and Upsert DB
}
答案 11 :(得分:0)
string name = "some node name";
var xDoc = XDocument.Load("yourFile");
var docRoot = xDoc.Element("your docs root name");
var aNode = docRoot.Elements().Where(x => x.Name == name).FirstOrDefault();
if (aNode == null)
{
return $"file has no {name}";
}
答案 12 :(得分:-2)
///我在第二个但最后一个位置找到子节点ERNO 如果StrComp(xmlnode(i).ChildNodes.Item(xmlnode(i).ChildNodes.Count-1).Name.ToString(),“ ERNO”,CompareMethod.Text)= 0然后 xmlnode(i).ChildNodes.Item(xmlnode(i).ChildNodes.Count-1).InnerText = c 其他 elem = xmldoc.CreateElement(“ ERNo”) elem.InnerText = c.ToString root.ChildNodes(i).AppendChild(elem) 如果结束