博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ios非UTF-8格式的网页解析
阅读量:4537 次
发布时间:2019-06-08

本文共 1449 字,大约阅读时间需要 4 分钟。

网上有很多关于ios xml解析的方法,关于非UTF-8格式的网页解析也不少,我也试着看了好几个,但都没成功。今天无意中却弄好了,所以想和大家分享下。其实很简单,下面说下怎么得到非UTF-8格式的网页要解析的代码内容,这也是比较关键的一步,剩余的解析过程网上很多,这里就不在赘述了,如果实在有需要得话,再跟我联系。

1、以百度(http://www.baidu.com)为例,其网页格式为gb2312,新建一个项目project,在-(void)viewDidLoad内输入一下内容:

1NSURL *url = [NSURL URLWithString:@"http://www.baidu.com"];
3NSStringEncoding encode = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);
4NSData *data = [NSData dataWithContentsOfURL:url];//得到的是十六进制数据
5NSLog(@"data:%@",data);
6
 
7NSString *str = [[NSString alloc] initWithData:data encoding:encode];
8NSLog(@"str:%@",str);
 
第一个NSLog输出的部分内容截图:

第二个NSLog输出的部分内容截图:

这就是能识别得GB2312格式的网页,通过“右击--查看元素”可以得到,也是我们要解析的内容。

实际上,上面的代码还可以直接写成:

1NSURL *url = [NSURL URLWithString:@"http://www.baidu.com"];

2NSStringEncoding encode = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);

3 http://www.huiyi8.com/css3/​
4NSString *str = [[NSString alloc] initWithContentsOfURL:url encoding:encode error:nil];
5NSLog(@"htmlEncoding:%@",str);

得到得内容和第一种情况下第二个输出数据是一样的。

 

2、考虑了一下,我把UTF-8格式的网页解析第一步也写下,以便对比。以新浪微博( http://www.weibo.com)为例,其网页格式为UTF-8的,在-(void)viewDidLoad内输入一下内容:

1NSURL *url2 = [NSURL URLWithString:@"http://www.weibo.com"];

2NSString *str2 = [NSString stringWithContentsOfURL:url2 encoding:NSUTF8StringEncoding error:nil];

3NSLog(@"str2:%@",str2);

输出的部分内容截图 :

 

这正是我们要解析的内容,剩余的解析需要添加对应的库、文件、修改Build Settings设置等,这些网上都有,就不说了。

 

转载于:https://www.cnblogs.com/xkzy/p/3812014.html

你可能感兴趣的文章
Cocoa编程开发者手册
查看>>
C++框架_之Qt的开始部分_概述_安装_创建项目_快捷键等一系列注意细节
查看>>
理工之 A+B Problem III
查看>>
SalesForce自定义按钮(javascript执行),点击按钮更新Filed
查看>>
软件工程第一次作业
查看>>
【Android 界面效果24】Intent和PendingIntent的区别
查看>>
node学习之搭建服务器并加装静态资源
查看>>
android 按menu键解锁功能的开关
查看>>
wpf 自定义窗口,最大化时覆盖任务栏解决方案
查看>>
Linux 下的dd命令使用详解
查看>>
POJ-1273 Drainage Ditches 最大流Dinic
查看>>
ASP.NET学习记录点滴
查看>>
uva 12097(二分)
查看>>
[Noip2016] 愤怒的小鸟
查看>>
Linux系统基础管理
查看>>
JAVA wait()和notifyAll()实现线程间通讯
查看>>
python全栈脱产第11天------装饰器
查看>>
koa2 从入门到进阶之路 (一)
查看>>
Java / Android 基于Http的多线程下载的实现
查看>>
求职历程-----我的简历
查看>>