0

我有一个具有以下结构的 XML 文件:

<?xml version='1.0' encoding='UTF8'?>
<root>
    <row filter="FILTER STRING"> // THIS IS THE FIRST "ROW"
        <id>100</id>
        <name>Some nome here</name>
        <text>TEXT CONTENT HERE</text>
    </row>
    <row filter="FILTER STRING"> // THIS IS THE SECOND "ROW"
        <id>101</id>
        <name>Some nome here</name>
        <text>TEXT CONTENT HERE</text>
    </row>
</root>

我将在一个 XML 文件中包含很多行节点,并且我无法更改此结构。

那么,对于 XML 包,我应该如何进行才能从特定节点获取文本内容?

例如,我想从第二行中名为“名称”的节点获取文本。

编辑:

至今:

void main() {
    _readFile("test_UTF8.xml").then((xmlContent) {
        var parsedXml = parse(xmlContent);
            parsedXml.findAllElements("row").forEach((row) {
                // EACH "ROW" NODE WILL BE ITERATED HERE.
                // READ "ROW" CHILDREN NODES HERE.
                // FOR EXAMPLE: GET "NAME"'S TEXT CONTENT.
            });
    });
}

Future _readFile(String filename) {
    var completer = new Completer();
    new File(filename).readAsString().then((String xmlContent) {
        completer.complete(xmlContent);
    });
    return completer.future;
}
4

1 回答 1

1

你可能不需要Completer这里

Future _readFile(String filename) {
  // a return here achieves the same in most cases
  return new File(filename).readAsString();
  // because this makes this method so short it doen't make much sense to 
  // even create a method for this
}

我实际上并没有尝试过这段代码,但根据README.md包它应该像这样工作:

void main() {
  new File("test_UTF8.xml").readAsString()
  .then((xmlContent) {
    var parsedXml = parse(xmlContent);
    return parsedXml.findElements("root")
        .first.findElements("row").toList()[1]
            .findElements('name').first.text; // <= modified
  })
  .then((text) {
    print(text);
  }); 
}
于 2014-11-12T14:24:44.690 回答