0

XML ファイルの一部の要素の stringValue に、BOM 文字が含まれています。xml ファイルは UTF-8 エンコーディングとしてマークされています。

これらの文字の一部は文字列の先頭にあります (私が読んだものからそうあるべきです) が、一部は文字列の途中にあります (xml ファイルを書いた人からの不正な文字列でしょうか?)。

私はファイルを開いています:

NSURL *furl = [NSURL fileURLWithPath:fileName];
if (!furl) {
    NSLog(@"Error: Can't open NML file '%@'.", fileName);

    return kNxADbReaderTTError;
}

NSError *err=nil;

NSXMLDocument *xmlDoc = [[NSXMLDocument alloc] initWithContentsOfURL:furl options:NSXMLNodeOptionsNone error:&err];

そして、この方法で要素をクエリします。

NSXMLElement *anElement;
NSString *name;
...
NSString *valueString = [[anElement attributeForName:name] stringValue];

私の質問は次のとおりです。

ファイルを間違って開いていますか?ファイルの形式が正しくありませんか? 要素の文字列値のクエリが間違っていますか? これらの文字を除外するにはどうすればよいですか?

4

1 に答える 1

0

別の問題を修正しているときに、NSXMLDocument のソースから不要な文字を除外する比較的クリーンな方法を見つけました。誰かが同様の問題に遭遇した場合に備えて、ここに貼り付けます。

@implementation NSXMLDocument (FilterIllegalCharacters)

    - (NSXMLDocument *)initWithDataAndIgnoreIllegalCharacters:(NSData *)data illegalChars:(NSCharacterSet *)illegalChars error:(NSError **)error{
    // -- Then, read the resulting XML string.
    NSMutableString *str = [[NSMutableString alloc] initWithData:data encoding:NSUTF8StringEncoding];

    // -- Go through the XML, only caring about attribute value strings
    NSMutableArray *charactersToRemove = [NSMutableArray array];
    NSUInteger openQuotes = NSNotFound;
    for (NSUInteger pos = 0; pos < str.length; ++pos) {
        NSUInteger currentChar = [str characterAtIndex:pos];

        if (currentChar == '\"') {
            if (openQuotes == NSNotFound) {
                openQuotes = pos;
            }
            else {

                openQuotes = NSNotFound;
            }
        }
        else if (openQuotes != NSNotFound) {
            // -- If we find an illegal character, we make a note of its position.
            if ([illegalChars characterIsMember:currentChar]) {
                [charactersToRemove addObject:[NSNumber numberWithLong:pos]];
            }
        }
    }

    if (charactersToRemove.count) {
        NSUInteger index = charactersToRemove.count;

        // -- If we have characters to fix, we work thru them backwards, in order to not mess up our saved positions by modifying the XML.
        do {
            --index;

            NSNumber *characterPos = charactersToRemove[index];
            [str replaceCharactersInRange:NSMakeRange(characterPos.longValue, 1) withString:@""];
        }
        while (index > 0);

        // -- Finally we update the data with our corrected version
        data = [str dataUsingEncoding:NSUTF8StringEncoding];
    }

    return [[NSXMLDocument alloc] initWithData:data options:NSXMLNodeOptionsNone 

    error:error];
}

@end

任意の文字セットを渡すことができます。これにより、XML ドキュメントを読み取るためのオプションが none に設定されることに注意してください。独自の目的のためにこれを変更したい場合があります。

これは、属性文字列のコンテンツのみをフィルタリングします。これは、私の不正な文字列の由来です。

于 2013-07-11T19:12:45.730 に答える