Разбор xml с помощью NSXMLParser

Я пытаюсь проанализировать файл xml, используя NSXMLParser. Мой NSXMLParserDelegate реализует parser:didStartElement и parser:didEndElement и получает сообщения от синтаксического анализатора для каждого элемента. Но когда я пытаюсь их распечатать, я обнаруживаю, что сообщения пусты. Что мне не хватает?

Мой делегат:

@interface ExtensionXML : NSObject <NSXMLParserDelegate> {
    @private NSXMLParser* xmlParser;
    @private NSURL*       fileUrl;
}
- (void) parse;           
- (ExtensionXML*) initWithPath: (NSString*)path;
@end

@implementation ExtensionXML
- (ExtensionXML*) initWithPath: (NSString*)path
{
     if (self = [super init])
     {
         fileUrl = [NSURL fileURLWithPath:[path  stringByExpandingTildeInPath]]; // error handling
     }
    return self;
}

- (void) parse
{
   xmlParser = [[NSXMLParser alloc] initWithContentsOfURL:fileUrl];
   [xmlParser setDelegate:self];
   [xmlParser setShouldResolveExternalEntities:YES];
   [xmlParser setShouldProcessNamespaces:YES];
   [xmlParser setShouldReportNamespacePrefixes:YES];
   [xmlParser parse];
}
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qualifiedName attributes:(NSDictionary *)attributeDict
{
    NSLog(@"start: element %s uri %s qualified name %s", elementName, namespaceURI, qualifiedName);
}

- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qualifiedName attributes:(NSDictionary *)attributeDict
{
    NSLog(@"end: element %s uri %s qualified name %s", elementName, namespaceURI, qualifiedName);
}
@end 

XML-файл:

<someroot xmlns="http://ns.mycompany.com/product/format/1.3">
    <id>myid</id>
    <version>1</version>
    <components>
        <component name="componentOne">
                <initializer>Init0</initializer>
        </component>
    </components>
</someroot>

Вывод из NSLog показывает, что elementName, namespaceURI и qualifierName пусты.


person 341008    schedule 19.03.2011    source источник


Ответы (1)


Чтобы регистрировать NSString, используйте %@ вместо %s. Измените обе строки NSLog. См. спецификаторы формата строк для список спецификаторов с указанием их использования.

Другая проблема заключается в том, что метод делегата didEndElement не имеет параметра атрибутов, поэтому написанный вами метод не будет вызываться. Так должно быть:

- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName 
    namespaceURI:(NSString *)namespaceURI 
    qualifiedName:(NSString *)qualifiedName
{
    NSLog(@"end: element %@ uri %@ qualified name %@", 
                elementName, namespaceURI, qualifiedName);
}
person Community    schedule 19.03.2011