gpt4 book ai didi

ios - 使用 Hpple 在 Xcode 中解析 xml

转载 作者:行者123 更新时间:2023-11-29 12:26:56 24 4
gpt4 key购买 nike

我有一些看起来像这样的 xml:

<menu>
<day name="monday">
<meal name="BREAKFAST">
<counter name="Bread">
<dish>
<name>Plain Bagel
<info name="Plain Bagel">
<serving>1 Serving (90g)</serving>
<calories>200</calories>
<caloriesFromFat>50</caloriesFromFat>
</info>
</name>
</dish>
<dish>
<name>Applesauce Coffee Cake
<info name="Applesauce Coffee Cake">
<serving>1 Slice-Cut 12 (121g)</serving>
<calories>374</calories>
<caloriesFromFat>104</caloriesFromFat>
</info>
</name>
</dish>
</counter>
</meal>
</day>
</menu>

现在我正在尝试获取 info 标签下的标签数量,对于具有 属性的第一个 info 标签来说应该是三个>普通百吉饼

就像我说的,我正在使用适用于 iOS 的 Hpple 解析器。这是我所拥有和正在尝试但无法完全正常工作的东西。

- (void)getData:(NSData*)factData {
TFHpple *Parser = [TFHpple hppleWithHTMLData:factData];
NSString *XpathQueryString = @"//day[@name='monday']/meal[@name='BREAKFAST']/counter[@name='Bread']/dish/name/info[@name='Plain Bagel']";
NSArray *Nodes = [Parser searchWithXPathQuery:XpathQueryString];
NSInteger count = Nodes.count;
NSLog(@"count: %ld", count);
for (TFHppleElement *element in Nodes) {
NSLog(@"count inside: %ld", element.children.count);
}
}

第一个计数给出 1。这是正确的,但内部计数给出 7,这是我感到困惑的地方。并且不确定为什么会这样。进入 info 标签后,我想遍历每个标签、服务、卡路里和来自脂肪的卡路里,并获取每个标签文本。但我不确定为什么它给出 7?

提前感谢您的帮助。

最佳答案

问题是您使用的是 HTML 解析器而不是 XML 解析器。从 HTML 的角度来看,info 开始和结束标记之间有七个元素:

  • 一些文本(换行符和空格)
  • 服务标签
  • 一些文本(换行符和空格)
  • 卡路里标签
  • 一些文本(换行符和空格)
  • caloriesFromFat 标签
  • 一些文本(换行符和空格)

如果您遍历 children 对象,您会准确地看到这一点。

如果您只想要与标签关联的条目,您可以检查节点是否有自己的子节点:

TFHpple *parser = [TFHpple hppleWithXMLData:factData];
NSString *xpathQueryString = @"//day[@name='monday']/meal[@name='BREAKFAST']/counter[@name='Bread']/dish/name/info[@name='Plain Bagel']";
NSArray *nodes = [parser searchWithXPathQuery:xpathQueryString];
for (TFHppleElement *element in nodes) {
for (TFHppleElement *child in element.children) {
if (child.children.count > 0) { // see if the child, itself, has children
NSLog(@" %@: '%@'", child.tagName, child.content);
}
}
}

或者您可以使用谓词:

TFHpple *parser = [TFHpple hppleWithXMLData:factData];
NSString *xpathQueryString = @"//day[@name='monday']/meal[@name='BREAKFAST']/counter[@name='Bread']/dish/name/info[@name='Plain Bagel']";
NSArray *nodes = [parser searchWithXPathQuery:xpathQueryString];
NSPredicate *predicate = [NSPredicate predicateWithBlock:^BOOL(TFHppleElement *node, NSDictionary *bindings) {
return node.children.count > 0;
}];
for (TFHppleElement *element in nodes) {
NSArray *filteredNodes = [element.children filteredArrayUsingPredicate:predicate];
for (TFHppleElement *child in filteredNodes) {
NSLog(@" %@: '%@'", child.tagName, child.content);
}
}

如果您使用的是适当的 XML 解析器(例如 NSXMLParser),您就不会处理开始标签和结束标签之间的随机字符。

关于ios - 使用 Hpple 在 Xcode 中解析 xml,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28788724/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com