- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图解析一些由3ds max和maya生成的xml文件。一切正常,但有些值返回 null。例如,考虑下面由 max 或 maya 生成的 XML(带有 .dae 扩展名的 collada),
<triangles>
<p> 234 32 4 23 544 35 43 5 435</p>
</triangles>
<triangles>
<p> 43543 45 34 5 12 34 4 36457 6</p>
</triangles>
<triangles>
<p>2345 325 34 543 5 34 534 5 435</p>
</triangles>
现在,当我使用 java 代码进行解析时(如果需要,我将提供),
输出为:
p has 234 32 4 23 544 35 43 5 435
p has
p has 2345 325 34 543 5 34 534 5 435
即使有值,第二行输出也不会显示任何内容。现在,如果我自己编辑该行,输出将按预期显示,即输出如下所示,这里我在 xml 文件中给出了自己的值。
编辑后的xml为
<triangles>
<p> 234 32 4 23 544 35 43 5 435</p>
</triangles>
<triangles>
<p> 28 234 34 32 4 23 4 23 423 43</p>
</triangles>
<triangles>
<p>2345 325 34 543 5 34 534 5 435</p>
</triangles>
输出是:
p has 234 32 4 23 544 35 43 5 435
p has 28 234 34 32 4 23 4 23 423 43
p has 2345 325 34 543 5 34 534 5 435
上面我已经解释了我面临的问题。 Here你可以找到maya生成的文件。下面给出了我使用的java代码。
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class Main {
public static void main(String args[]) {
try {
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder();
Document doc = docBuilder.parse (new File("d://tablemaya.dae"));
// normalize text representation
doc.getDocumentElement ().normalize ();
System.out.println ("Root element of the doc is " +
doc.getDocumentElement().getNodeName());
NodeList listOfPersons = doc.getElementsByTagName("library_geometries");
int totalPersons = listOfPersons.getLength();
System.out.println("Total no of people : " + totalPersons);
Node firstPersonNode = listOfPersons.item(0);
if(firstPersonNode.getNodeType() == Node.ELEMENT_NODE){
Element firstPersonElement = (Element)firstPersonNode;
//-------
NodeList geometrylist = firstPersonElement.getElementsByTagName("geometry");
System.out.println(geometrylist.getLength() + " Geometry size");
for(int k=0;k<geometrylist.getLength();k++) {
Element geometryItr = (Element)geometrylist.item(k);
NodeList meshlist = geometryItr.getElementsByTagName("mesh");
System.out.println("Mesh length is " + meshlist.getLength());
for(int k1=0;k1<meshlist.getLength();k1++) {
Element geometryItr1 = (Element)meshlist.item(k1);
NodeList meshlist1 = geometryItr1.getElementsByTagName("source");
System.out.println("Source length is " + meshlist1.getLength());
}
for(int k2=0;k2<meshlist.getLength();k2++) {
Element geometryItr1 = (Element)meshlist.item(k2);
NodeList trianglelist = geometryItr1.getElementsByTagName("triangles");
//System.out.println("Triangles length is " + trianglelist.getLength());
for(int o=0;o<trianglelist.getLength();o++) {
Element trichildnodes = (Element) trianglelist.item(o);
NodeList inputs = trichildnodes.getElementsByTagName("input");
NodeList p = trichildnodes.getElementsByTagName("p");
//System.out.println("Fucking Problem " + p.item(0).getFirstChild().getNodeValue());
Element ppp = (Element) p.item(0);
//System.out.println("Node Value " + ppp.getNodeValue());
System.out.println(inputs.getLength() + "Input length");
for(int in=0;in<inputs.getLength();in++) {
Element inn = (Element) inputs.item(in);
System.out.println(inn.getAttribute("semantic") + " " + inn.getAttribute("source") + " Attributes");
}
for(int i=0; i<p.getLength(); i++) {
Element e = (Element)p.item(i);
String ss = e.getFirstChild().getTextContent();
System.out.println("Noide is " + ss);
}
//System.out.println(p.getLength() + " P's length" );
//System.out.println("P's content " + ppp.getFirstChild().getNodeValue());
}
}
for(int k1=0;k1<meshlist.getLength();k1++) {
Element geometryItr1 = (Element)meshlist.item(k1);
NodeList meshlist1 = geometryItr1.getElementsByTagName("vertices");
System.out.println("Vertices length is " + meshlist1.getLength());
}
}
}
}catch (Exception err) {
err.printStackTrace();
}
}
}
我无法获取 <p>
的所有内容。我的代码或 xml 可能有什么问题?请有人在这方面帮助我。感谢您阅读我的问题。
维奈
最佳答案
这可能是 Eclipse 的错误。你的代码似乎是正确的,我写了 my own XPath demo 来测试输入文件。该程序在 Eclipse 中运行良好,但是当我尝试输出 <p>
时内容来自 System.out.println()
,第二个<p>
没有打印到 Eclipse 控制台,因为该行字符太多(超过 30K)。请参阅this comment在 Eclipse bugzilla 上:
I get weird things happening with the console on the Mac, when printing long lines eg:
public static void main(String[] args)
{
System.out.print("Counting");
StringBuffer buffer = new StringBuffer();
for (int i=0; i<28504; i++)
{
buffer.append("*");
}
System.out.print(" some more");
System.out.println(buffer);
System.out.println("Complete");
}The output I get from this is as follows:
Counting some
Completeie the long string of '*' isn't displayed and overwrites part of the preceding output
Steve
因此文件已成功读取和处理,目标信息已完全收集,只有输出部分失败,但这不取决于您 - 并且它不会影响程序,因为我认为这不是您想要的正在向用户的眼睛打印一大行文本
关于java - XML 解析对某些标签返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11699382/
我一直在使用 AJAX 从我正在创建的网络服务中解析 JSON 数组时遇到问题。我的前端是一个简单的 ajax 和 jquery 组合,用于显示从我正在创建的网络服务返回的结果。 尽管知道我的数据库查
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我在尝试运行 Android 应用程序时遇到问题并收到以下错误 java.lang.NoClassDefFoundError: com.parse.Parse 当我尝试运行该应用时。 最佳答案 在这
有什么办法可以防止etree在解析HTML内容时解析HTML实体吗? html = etree.HTML('&') html.find('.//body').text 这给了我 '&' 但我想
我有一个有点疯狂的例子,但对于那些 JavaScript 函数作用域专家来说,它看起来是一个很好的练习: (function (global) { // our module number one
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我需要编写一个脚本来获取链接并解析链接页面的 HTML 以提取标题和其他一些数据,例如可能是简短的描述,就像您链接到 Facebook 上的内容一样。 当用户向站点添加链接时将调用它,因此在客户端启动
在 VS Code 中本地开发时,包解析为 C:/Users//AppData/Local/Microsoft/TypeScript/3.5/node_modules/@types//index而不是
我在将 json 从 php 解析为 javascript 时遇到问题 这是我的示例代码: //function MethodAjax = function (wsFile, param) {
我在将 json 从 php 解析为 javascript 时遇到问题 这是我的示例代码: //function MethodAjax = function (wsFile, param) {
我被赋予了将一种语言“翻译”成另一种语言的工作。对于使用正则表达式的简单逐行方法来说,源代码过于灵活(复杂)。我在哪里可以了解更多关于词法分析和解析器的信息? 最佳答案 如果你想对这个主题产生“情绪化
您好,我在解析此文本时遇到问题 { { { {[system1];1;1;0.612509325}; {[system2];1;
我正在为 adobe after effects 在 extendscript 中编写一些代码,最终变成了 javascript。 我有一个数组,我想只搜索单词“assemble”并返回整个 jc3_
我有这段代码: $(document).ready(function() { // }); 问题:FB_RequireFeatures block 外部的代码先于其内部的代码执行。因此 who
背景: netcore项目中有些服务是在通过中间件来通信的,比如orleans组件。它里面服务和客户端会指定网关和端口,我们只需要开放客户端给外界,服务端关闭端口。相当于去掉host,这样省掉了些
1.首先贴上我试验成功的代码 复制代码 代码如下: protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)
什么是 XML? XML 指可扩展标记语言(eXtensible Markup Language),标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。 你可以通过本站学习 X
【PHP代码】 复制代码 代码如下: $stmt = mssql_init('P__Global_Test', $conn) or die("initialize sto
在SQL查询分析器执行以下代码就可以了。 复制代码代码如下: declare @t varchar(255),@c varchar(255) declare table_cursor curs
前言 最近练习了一些前端算法题,现在做个总结,以下题目都是个人写法,并不是标准答案,如有错误欢迎指出,有对某道题有新的想法的友友也可以在评论区发表想法,互相学习🤭 题目 题目一: 二维数组中的
我是一名优秀的程序员,十分优秀!