Merge branch 'master' of https://git.dirt.kz/igor/Tools_java
# Conflicts: # XMLTools.java # xml/XMLTools.java # xmltools/XMLTools.java
This commit is contained in:
@ -87,24 +87,8 @@ public class XMLTools
|
||||
return node instanceof Element && node.getNodeName().equals(tagname);
|
||||
}
|
||||
|
||||
/** Найти узел по атрибуту
|
||||
*/
|
||||
public static Node findNodeOnAttribute(Node node, String nodename, String attribute, String val)
|
||||
{
|
||||
if(node==null) return null;
|
||||
NodeList items = node.getChildNodes();
|
||||
for (int i=0;i<items.getLength();i++)
|
||||
{
|
||||
Node n=items.item(i);
|
||||
if(n.getNodeName().equals(nodename))
|
||||
{
|
||||
NamedNodeMap nnm=n.getAttributes();
|
||||
if(nnm.getNamedItem(attribute).getNodeValue().equals(val)) return n;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
<<<<<<<< HEAD:xmltools/XMLTools.java
|
||||
========
|
||||
//вернуть первый попавшийся узел среди дочерних
|
||||
public static Node getFirstNodeOnName(Node node,String nodename)
|
||||
{
|
||||
@ -158,6 +142,106 @@ public class XMLTools
|
||||
return null;
|
||||
}
|
||||
|
||||
//Сериализовать узел в строку
|
||||
public static String getOuterXML(Node node)
|
||||
{
|
||||
DOMImplementationLS domImplementation = (DOMImplementationLS) node.getOwnerDocument().getImplementation();
|
||||
LSSerializer lsSerializer = domImplementation.createLSSerializer();
|
||||
if (!(node instanceof Document))
|
||||
{
|
||||
lsSerializer.getDomConfig().setParameter("xml-declaration", false);
|
||||
}
|
||||
return lsSerializer.writeToString(node);
|
||||
}
|
||||
|
||||
>>>>>>>> bd22e57cbce7dba632e6c46bb0e627e3b0f388f7:xml/XMLTools.java
|
||||
/** Найти узел по атрибуту
|
||||
*/
|
||||
public static Node findNodeOnAttribute(Node node, String nodename, String attribute, String val)
|
||||
{
|
||||
if(node==null) return null;
|
||||
NodeList items = node.getChildNodes();
|
||||
for (int i=0;i<items.getLength();i++)
|
||||
{
|
||||
Node n=items.item(i);
|
||||
if(n.getNodeName().equals(nodename))
|
||||
{
|
||||
NamedNodeMap nnm=n.getAttributes();
|
||||
if(nnm.getNamedItem(attribute).getNodeValue().equals(val)) return n;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
<<<<<<<< HEAD:xmltools/XMLTools.java
|
||||
//вернуть первый попавшийся узел среди дочерних
|
||||
public static Node getFirstNodeOnName(Node node,String nodename)
|
||||
{
|
||||
Node[] mas=new Node[50]; //depth
|
||||
int pos=0;
|
||||
mas[pos] = node.getFirstChild();
|
||||
while (mas[pos] != null)
|
||||
{
|
||||
if(mas[pos].getNodeName().equals(nodename))
|
||||
{
|
||||
return mas[pos];
|
||||
}
|
||||
if(mas[pos].getFirstChild()!=null)
|
||||
{
|
||||
pos++;
|
||||
mas[pos]=mas[pos-1].getFirstChild();
|
||||
}else
|
||||
{
|
||||
//если не идёт дальше пытаемся подняться в верх по дереву
|
||||
while (true)
|
||||
{
|
||||
mas[pos] = mas[pos].getNextSibling();
|
||||
if (mas[pos]==null)
|
||||
{
|
||||
if(pos>0){ pos--; }else{ break; }
|
||||
}else
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return first from childs in first deep level on name
|
||||
* @param node Find in
|
||||
* @param nodename Name node
|
||||
* @return node
|
||||
*/
|
||||
public static Node getNodeOnName(Node node,String nodename)
|
||||
{
|
||||
if(node==null) return null;
|
||||
Node nextNode = node.getFirstChild();
|
||||
while(nextNode != null)
|
||||
{
|
||||
if(nextNode.getNodeName().equals(nodename)) return nextNode;
|
||||
nextNode=nextNode.getNextSibling();
|
||||
========
|
||||
public static Node findFirstNodeOnAttribute(Node node, String nodename,String attribute,String val)
|
||||
{
|
||||
Node result=null;
|
||||
if(node==null) return result;
|
||||
javax.xml.xpath.XPathFactory xPathfactory = javax.xml.xpath.XPathFactory.newInstance();
|
||||
XPath xpath = xPathfactory.newXPath();
|
||||
XPathExpression expr=null;
|
||||
Object exprResult=null;
|
||||
try {
|
||||
expr = xpath.compile("//*/"+nodename+"[@"+attribute+"='" + val + "']");
|
||||
exprResult = expr.evaluate(node, XPathConstants.NODESET);
|
||||
} catch (XPathExpressionException ex) {
|
||||
|
||||
>>>>>>>> bd22e57cbce7dba632e6c46bb0e627e3b0f388f7:xml/XMLTools.java
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
//Сериализовать узел в строку
|
||||
public static String getOuterXML(Node node)
|
||||
{
|
||||
@ -216,6 +300,10 @@ public class XMLTools
|
||||
}
|
||||
return null;
|
||||
}
|
||||
<<<<<<<< HEAD:xmltools/XMLTools.java
|
||||
========
|
||||
|
||||
>>>>>>>> bd22e57cbce7dba632e6c46bb0e627e3b0f388f7:xml/XMLTools.java
|
||||
/** Найти узел по атрибуту
|
||||
*/
|
||||
public static Node findNodeOnAttribute(Node node, String nodename, String attribute, String val)
|
||||
|
||||
Reference in New Issue
Block a user