- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我只是想制作一个 XML 阅读器,但遇到了一些麻烦。当我解析 XML 文件时,它说只有一个标签并只读取这个标签。但是不止一个。这是我的代码:
@Override
protected Void doInBackground(Void... voids) {
try {
URL url = new URL(QuizActivity.fileUrl);
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse(new InputSource(url.openStream()));
document.getDocumentElement().normalize();
NodeList sorular = document.getElementsByTagName("sorular");
Log.d("Soru Sayısı", String.valueOf(sorular.getLength()));
for(int i = 0; i < sorular.getLength(); i++){
Node sorularNode = sorular.item(i);
Element sorularElement = (Element) sorularNode;
NodeList siraNodeList = document.getElementsByTagName("sira");
Element siraElement = (Element) siraNodeList.item(i);
NodeList textNodeList = document.getElementsByTagName("text");
Element textElement = (Element) textNodeList.item(i);
NodeList aNodeList = document.getElementsByTagName("a");
Element aElement = (Element) aNodeList.item(i);
NodeList bNodeList = document.getElementsByTagName("b");
Element bElement = (Element) bNodeList.item(i);
NodeList cNodeList = document.getElementsByTagName("c");
Element cElement = (Element) cNodeList.item(i);
NodeList dNodeList = document.getElementsByTagName("d");
Element dElement = (Element) dNodeList.item(i);
NodeList eNodeList = document.getElementsByTagName("e");
Element eElement = (Element) eNodeList.item(i);
NodeList dogruNodeList = document.getElementsByTagName("dogru");
Element dogruElement = (Element) dogruNodeList.item(i);
int sira = Integer.parseInt(siraElement.getChildNodes().item(i).getNodeValue());
SinavActivity.soruText.put(sira, textElement.getChildNodes().item(i).getNodeValue());
SinavActivity.cevap_a.put(sira, aElement.getChildNodes().item(i).getNodeValue());
SinavActivity.cevap_b.put(sira, bElement.getChildNodes().item(i).getNodeValue());
SinavActivity.cevap_c.put(sira, cElement.getChildNodes().item(i).getNodeValue());
SinavActivity.cevap_d.put(sira, dElement.getChildNodes().item(i).getNodeValue());
SinavActivity.cevap_e.put(sira, eElement.getChildNodes().item(i).getNodeValue());
SinavActivity.dogruCevap.put(sira, dogruElement.getChildNodes().item(i).getNodeValue().trim());
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
}
return null;
}
XML 文件:
<?xml version="1.0" encoding="utf-8"?>
<sorular>
<Matematik>
<soru>
<sira>1</sira>
<text>Bir sınıftaki öğrencilerin % 40 ı kız öğrencidir. Kız öğrencilerin % 90 ı, erkek öğrencilerin %80 matematik dersinden başarılıdır. Buna göre, bu sınıfın matematik dersinden başarısı yüzde kaçtır?</text>
<a>84</a>
<b>46</b>
<c>20</c>
<d>12</d>
<e>50</e>
<dogru>A</dogru>
</soru>
<soru>
<sira>2</sira>
<text>A ve B boş olmayan 2 kümedir 2.s(A)=3.s(B)= 5.s(A ∩ B) olduğuna göre s(A-B) en az kaçtır?</text>
<a>8</a>
<b>10</b>
<c>2</c>
<d>9</d>
<e>12</e>
<dogru>D</dogru>
</soru>
</Matematik>
如果我写 NodeList sorular = document.getElementsByTagName("sorular");
它表示计数 NodeList = 1
但如果我写 NodeList sorular = document .getElementsByTagName("soru");
它说 count = 2
但它给了我一个 NullPointerException
最佳答案
因为 siraElement.getChildNodes().getLength()
将始终返回 1
元素,所以当
siraElement.getChildNodes().item(i).getNodeValue() //i=0
所以第一个节点将位于 0
索引处,但是当 i=1
时,索引 1< 处将没有
Node
/
siraElement.getChildNodes().item(i).getNodeValue() //i=1 error
所以你可以从 0
索引中获取 always
int sira = Integer.parseInt(siraElement.getChildNodes().item(0).getNodeValue());
// ^^
对下面的所有值做同样的事情
textElement.getChildNodes().item(0).getNodeValue()
...
dogruElement.getChildNodes().item(0).getNodeValue().trim()
关于java - Android XML Reader 读取一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42909324/
class ReadLock { private: std::mutex readWriteMutex; std::mutex conditionmtx; std::condi
我在 utf-8 编码文件中有多个 messages.properties 文件(messages_en_US.properties、messages_fr.properties,...)。在这些属性
我正在尝试从 google reader api 中检索单个选定项目。是否可以通过 API 调用通过 ID 获取项目,或者我是否必须访问该项目提要并从那里获取它? 最佳答案 您可以使用 POST 到
好的,所以我有一个应用程序可以与 GR 的“api”紧密结合。 一切正常,但最近我收到来自 Google 的许可被拒绝返回。如果我退出 GR 并使用我的应用程序重新登录,一切都会重新开始。这让我相信
我想要的是最终得到类似的东西: public class InterleavedBufferedReader extends BufferedReader { ... } 并将其用作: Reader[
reader monad 有一个asks 函数,它的定义与reader 函数完全相同,为什么它作为一个单独的函数存在,与 的定义相同读者?为什么不总是使用阅读器? class Monad m => M
当使用csv模块读取文件时,有两种方法可以遍历csv.reader返回的生成器。 with open('foo.csv') as f: reader = csv.reader(f) r
我想在 Go 中按照 here 中的要求做同样的事情. 我正在解析一个巨大的日志文件,我需要逐行解析它。在每一行上,我将该行反序列化为一个结构。数据可能来自任何数据源(文件、网络等)。因此,我在我的函
我在golang的zlib/reader.go文件中找到了很多像r.(flate.Reader)这样的代码片段。这是什么意思? https://golang.org/src/compress/zlib
我正在 Spring MVC 中包装 Freemarker 模板加载器,如所述 here在 html 页面中进行默认转义。 所以,我需要用我的字符串包装来自 java.io.Reader 的内容,而不
为什么这个 PDF 在 Foxit Reader 而不是 Adobe Reader 中显示签名? 这是来自 Syncfusion PDF library 的代码用于生成它(另请参阅有关 signi
我有一个巨大的tbb::concurrent_unordered_map被多个(~60)线程同时“大量读取”。 我每天需要清除一次(完全清除或选择性清除)。在 tbb 中删除显然不是线程安全的实现,因
好像是 Hibernate.createClob(Reader reader, int length)在 3.6.x 版本中已弃用 它建议使用使用 LobHelper.createClob(Reade
这是我的实际解决方案 private def transpose[E, A](readers : Seq[Reader[E, A]]) : Reader[E, Seq[A]] = Read
DataReader[0].ToString() 和 (string)DataReader[0] 有区别吗? 我的猜测是,如果数据库类型不是字符串类型,(string)DataReader[0] 可能
我想制作一个 C# 程序来保存 pdf 和 djvu 文件的书签。如何从 AcroRd32/DjVuReader 进程中找出当前页码? 最佳答案 您可以通过 Adobe Acrobat 支持的 D
什么更好 var s = (string)reader[0] 或 var s = Convert.ToString(reader[0]) ? 最佳答案 我会说 reader.GetString(0
我对非官方阅读器 api 进行了大量研究,并筛选了其他问题,但没有一个完全满足我的要求。如果您知道文章 id 有据可查,如何分享文章,但如果您不知道 id,我想知道如何分享文章(即如何转换 url -
这是一个简单的示例,用于将 xml 文件读入 WebRowSet 对象,然后将数据从该对象加载到数据库。 import javax.sql.rowset.RowSetProvider; import
这样的转换对于任何仿函数都是可能的,不仅是Future: implicit class RichFunctorReader[F[_]: Functor, A, B](fr: F[Reader[A, B
我是一名优秀的程序员,十分优秀!