2 回答

TA贡献1890条经验 获得超9个赞
试试这个
try {
File inputOne = new File("first.xml");
File inputTwo = new File("second.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document docOne = dBuilder.parse(inputOne);
Document docTwo = dBuilder.parse(inputTwo);
NodeList nodeListAhmed = docTwo.getElementsByTagName("ahmed");
for (int i = 0; i < nodeListAhmed.getLength(); i++) {
Node nodeMohamed = docTwo.importNode(docOne.getElementsByTagName("mohamed").item(0), true);
nodeListAhmed.item(i).appendChild(nodeMohamed);
}
DOMSource source = new DOMSource(docTwo);
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
StreamResult result = new StreamResult("output.xml");
transformer.transform(source, result);
} catch (Exception e) {
e.printStackTrace();
}

TA贡献1877条经验 获得超6个赞
我想要这个结果
<?xml version="1.0" encoding="UTF-8"?>
<ahmed
xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9
http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">
<!-- created with Free Online Sitemap Generator www.xml-sitemaps.com -->
stackover flow
</ahmed>
您可以使用.querySelector()来获取具有的元素tagName "mohamed",将.parentElement元素存储在变量中,将.textContent匹配元素的存储在变量中,使用从父元素中删除匹配的元素.removeChild(),将父元素设置.textContent为存储的变量
const xml = `<?xml version="1.0" encoding="UTF-8"?>
<ahmed
xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9 http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">
<!-- created with Free Online Sitemap Generator www.xml-sitemaps.com -->
<mohamed>stackover flow</mohamed>
</ahmed>`;
const parser = new DOMParser();
const doc = parser.parseFromString(xml, "text/xml");
let el = doc.querySelector("mohamed");
let parentElement = el.parentElement;
let text = el.textContent;
parentElement.removeChild(el);
parentElement.textContent = text;
console.log(`<?xml version="1.0" encoding="UTF-8"?>${doc.documentElement.outerHTML}`);
添加回答
举报