我搜寻了很多类似的问题,但找不到我的问题。

我有一个应用程序,其中嵌入了RSS feed文件。我要做的是,在根视图控制器中,加载该本地文件并进行解析,然后将数据显示在table view中。我还将每个项目的GUID保存在数组中。

我想从服务器上获取RSS feed链接并进行解析(如果用户可以访问互联网),然后将该文件中项目的GUID s保存到另一个数组,并比较两个数组,然后添加新的项目到我的表格视图中的当前列表。

我有NIKFeedEntry作为解析数据的NSObject模型,还有NSXMLParser。我用两个URL的两个不同的解析器对象实例化了它们,但是它们都被写在同一个对象中。因此,第一组已解析的数据会显示很短的时间,然后表视图会使用新的已解析的数据重新加载数据,并且我不知道如何解决此问题,因此在解析第二个URL之后,它将对两者进行比较如果有新的GUID数组,请将这些项(XML数据)附加到我的本地XML文件中,并显示新旧数据的组合。

这是我的NIKFeedEntry.m:

#import "NIKFeedEntry.h"

@implementation NIKFeedEntry

@synthesize lastBuildDate;
@synthesize radioTitle;
@synthesize podcastTitle;
@synthesize podcastDate;
@synthesize podcastURL;

@synthesize podcastAuthor;
@synthesize podcastContent;
@synthesize podcastGUID;
@synthesize podcastDownloadURL;
@synthesize podcastLinkURL;
@synthesize podcastSummary;
@synthesize categories;

- (id)initWithRadioTitle:(NSString*)radioTitle lastBuildDate:(NSDate*)lastBuildDate podcastTitle:(NSString*)podcastTitle podcastFile:(NSString*)podcastFile podcastDate:(NSDate*)podcastDate podcastDownloadURL:(NSString*)podcastDownloadURL
{
    return self;
}

@end

还有我的NIKFeedParser.m:
//  NIKFeedParser.m

#import "NIKFeedParser.h"
#import "NIKMasterViewController.h"

@class NIKMasterViewController;

NIKMasterViewController *masterVC;


@interface NIKFeedParser (Private)

- (NSString *)trimString:(NSString *)originalString;

@end

@implementation NIKFeedParser

@synthesize currentItem;
@synthesize currentItemValue;
@synthesize feedItems;
@synthesize delegate;
@synthesize retrieverQueue;
@synthesize parsingFeedsWithNumbers;
@synthesize queue;
@synthesize selectedCategory;
@synthesize feedURL;
@synthesize downloadURL;
@synthesize lastModified;
@synthesize RSSURL;
@synthesize updatedGUIDs;

- (id)initWithRSSURL:(NSURL *)rssURL{
    self = [super init];
    if (self) {
        feedItems = [[NSMutableArray alloc]init];
        RSSURL = rssURL;
    }
    return self;
}


- (NSOperationQueue *)retrieverQueue
{
    if (nil == retrieverQueue)
    {
        retrieverQueue = [[NSOperationQueue alloc] init];
        retrieverQueue.maxConcurrentOperationCount = 1;
    }

    return retrieverQueue;
}

- (void) startDownloading
{
//  ?? [feedItems removeAllObjects];
    NSString *file = [[NSBundle  mainBundle] pathForResource:@"Feed"
                                                      ofType:@"plist"];
    NSDictionary *item = [[NSDictionary alloc]initWithContentsOfFile:file];
    NSArray *array = [item objectForKey:@"Root"];
    NSString *theURL = [[array objectAtIndex:selectedCategory.intValue] objectForKey:@"URL"];
    NSLog(@"url:%@",theURL);
    NSURL * url = [NSURL URLWithString:theURL];
    NSURLRequest * urlRequest = [NSURLRequest requestWithURL:url];

    NSURLConnection * download = [[NSURLConnection alloc] initWithRequest:urlRequest delegate:self];
    [download start];
}

#pragma mark -
#pragma mark Private Methods


- (NSString *)trimString:(NSString *)originalString
{
    NSString * trimmedString;
    trimmedString  = [originalString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];
    return trimmedString;
}

#pragma mark -
#pragma mark NSURLConnectionDelegate

- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response
{
    //This method is called when the download begins.
    //You can get all the response headers

    /* create the NSMutableData instance that will hold the received data */

    long long contentLength = [response expectedContentLength];
    if (contentLength == NSURLResponseUnknownLength) {
        contentLength = 500000;
    }


    if (downloadedData!=nil)
    {
        downloadedData = nil;
    }
    downloadedData = [NSMutableData dataWithCapacity:(NSUInteger)contentLength];

}

- (void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data
{
    //This method is called whenever there is downloaded data available
    //It will be called multiple times and each time you will get part of downloaded data
    [downloadedData appendData:data];
}

- (void)connectionDidFinishLoading:(NSURLConnection *)connection
{
    //This method is called once the download is complete


    //The next step is parse the downloaded xml feed
    [feedItems removeAllObjects];
    NSXMLParser * xmlParser = [[NSXMLParser alloc] initWithData:downloadedData];
    [self startParsingWithParser:xmlParser];

    updatedGUIDs = [[NSMutableArray alloc] init];

    for (int i = 0; i < feedItems.count; i++) {
        [updatedGUIDs insertObject: [[feedItems objectAtIndex:i]podcastGUID]  atIndex:i];
    }

}

- (void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error
{

    [error localizedDescription];
    NSLog(@"%@", [error localizedDescription]);
    [self.delegate parserHasError:error];

}

#pragma mark -
#pragma mark NSXMLParserDelegate
- (void) startParsingWithParser: (NSXMLParser *)parser
{

    [parser setDelegate:self];
    [parser setShouldProcessNamespaces:YES];
    [parser setShouldReportNamespacePrefixes:YES];
    [parser setShouldResolveExternalEntities:NO];
    [parser parse];
}

- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qualifiedName attributes:(NSDictionary *)attributeDict
{
    if(nil != qualifiedName)
    {
        elementName = qualifiedName;
    }
    parseElement = NO;
    if ([elementName isEqualToString:@"lastBuildDate"])
    {
        lbd = [[NSString alloc] init];
    }

    if ([elementName isEqualToString:@"item"])
    {
        currentItem = [[NIKFeedEntry alloc] init];
    } else if([elementName isEqualToString:@"title"] ||
              [elementName isEqualToString:@"guid"] ||
              [elementName isEqualToString:@"description"] ||
              [elementName isEqualToString:@"content:encoded"] ||
              [elementName isEqualToString:@"link"] ||
              [elementName isEqualToString:@"category"] ||
              [elementName isEqualToString:@"dc:creator"] ||
              [elementName isEqualToString:@"pubDate"] ||
              [elementName isEqualToString:@"enclosure"] ||
              [elementName isEqualToString:@"lastBuildDate"])
    {
        NSString *urlValue=[attributeDict valueForKey:@"url"];
        NSString *urlType=[attributeDict valueForKey:@"type"];
        parseElement = YES;
        if ([urlType  isEqualToString:@"audio/ogg"] && ([urlValue rangeOfString:@"jadi.net"].length != 0))
        {
            downloadURL = [urlValue stringByReplacingOccurrencesOfString:@"jadi.net" withString:@"192.168.2.1"];
            downloadURL = [downloadURL stringByReplacingOccurrencesOfString:@"ogg" withString:@"mp3"];
            [currentItem setPodcastDownloadURL:downloadURL];
        }
    }

}


- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
{
    if(nil != qName)
    {
        elementName = qName;
    }

    NSString * parsedElementContent = nil;

    if (parsedElementData != nil) {
        parsedElementContent = [[NSString alloc] initWithData:parsedElementData encoding:NSUTF8StringEncoding];
    } else if (parsedElementString != nil) {
        parsedElementContent = [[NSString alloc] initWithString:parsedElementString];
    }
    if ([elementName isEqualToString:@"lastBuildDate"]) {
        NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
        [formatter setDateFormat:@"EEE, d MMM yyyy HH:mm:ss Z"];
        NSDate *lastSavedBuildDate = [formatter dateFromString:[self trimString:parsedElementContent]];
        [[NSUserDefaults standardUserDefaults] setObject:lastSavedBuildDate forKey:@"Date"];

    }
    if([elementName isEqualToString:@"title"])
    {
        [currentItem setPodcastTitle:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"guid"])
    {
        [currentItem setPodcastGUID:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"description"])
    {
        [currentItem setPodcastSummary:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"content:encoded"])
    {
        [currentItem setPodcastContent:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"link"])
    {
        [currentItem setPodcastLinkURL:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"category"])
    {
        [currentItem addPodcastCategory:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"dc:creator"])
    {
        [currentItem setPodcastAuthor:[self trimString:parsedElementContent]];
    }
    else if([elementName isEqualToString:@"pubDate"])
    {
        NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
        [formatter setDateFormat:@"EEE, d MMM yyyy HH:mm:ss Z"];
        [currentItem setPodcastDate:[formatter dateFromString:[self trimString:parsedElementContent]]];
    }
    else if([elementName isEqualToString:@"item"])
    {
        [feedItems addObject:currentItem];
        currentItem = nil;
    }

    if (parsedElementContent!=nil)
    {
        parsedElementContent = nil;
    }

    if (parsedElementString!=nil)
    {
        parsedElementString = nil;
    }

    if (parsedElementData!=nil)
    {
        parsedElementData = nil;
    }

}

- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
    if (!parseElement)
    {
        return;
    }
    if (parsedElementString==nil)
    {
        parsedElementString = [[NSMutableString alloc] init];
    }
    [parsedElementString appendString:string];
}

- (void)parser:(NSXMLParser *)parser parseErrorOccurred:(NSError *)parseError
{
    NSLog(@"parseErrorOccured: %@",[parseError localizedDescription]);

}

- (void)parserDidEndDocument:(NSXMLParser *)parser
{
    if (downloadedData!=nil)
    {
        downloadedData = nil;
    }
    [self.delegate parserDidCompleteParsing];
}

@end

最佳答案

NSXMLParserDelegate的所有方法都返回对调用方parser:(NSXMLParser *)parser的引用。您可以将其用于单独的数据。在属性中保留对解析器实例的引用,并与它们进行比较。

关于ios - 如何将解析的数据从不同的URL保存到NSXMLParser中的不同数组?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/20324618/

10-13 04:17
查看更多