博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# 抓取网页Html源码 (网络爬虫)
阅读量:6688 次
发布时间:2019-06-25

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

http://www.cnblogs.com/wxxian001/archive/2011/09/07/2169519.html

刚刚完成一个简单的网络爬虫,因为在做的时候在网上像无头苍蝇一样找资料。发现了很多的资料,不过真正能达到我需要,有用的资料--代码很难找。所以我想发这篇文章让一些要做这个功能的朋友少走一些弯路。

首先是抓取Html源码,并选择<ul class="post_list">  </ul>节点的href:要添加 using System.IO;using System.Net;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
private 
void 
Search(
string 
url)
{
    
string 
rl;
    
WebRequest Request = WebRequest.Create(url.Trim());
 
    
WebResponse Response = Request.GetResponse();
 
    
Stream resStream = Response.GetResponseStream();
 
    
StreamReader sr = 
new 
StreamReader(resStream, Encoding.Default);
    
StringBuilder sb = 
new 
StringBuilder();
    
while 
((rl = sr.ReadLine()) != 
null
)
    
{
        
sb.Append(rl);
    
}
 
 
    
string 
str = sb.ToString().ToLower();
 
    
string 
str_get = mid(str, 
"<ul class=\"post_list\">"
"</ul>"
);
 
 
    
int 
start = 0;
    
while 
(
true
)
    
{
        
if 
(str_get == 
null
)
            
break
;
        
string 
strResult = mid(str_get, 
"href=\""
"\""
out 
start);
        
if 
(strResult == 
null
)
            
break
;
        
else
        
{
            
lab[url] += strResult;
            
str_get = str_get.Substring(start);
        
}
    
}
}
 
 
 
 
private 
string 
mid(
string 
istr, 
string 
startString, 
string 
endString)
{
    
int 
iBodyStart = istr.IndexOf(startString, 0);               
//开始位置
    
if 
(iBodyStart == -1)
        
return 
null
;
    
iBodyStart += startString.Length;                           
//第一次字符位置起的长度
    
int 
iBodyEnd = istr.IndexOf(endString, iBodyStart);         
//第二次字符在第一次字符位置起的首次位置
    
if 
(iBodyEnd == -1)
        
return 
null
;
    
iBodyEnd += endString.Length;                              
//第二次字符位置起的长度
    
string 
strResult = istr.Substring(iBodyStart, iBodyEnd - iBodyStart - 1);
    
return 
strResult;
}
 
 
private 
string 
mid(
string 
istr, 
string 
startString, 
string 
endString, 
out 
int 
iBodyEnd)
{
    
//初始化out参数,否则不能return
    
iBodyEnd = 0;
 
    
int 
iBodyStart = istr.IndexOf(startString, 0);               
//开始位置
    
if 
(iBodyStart == -1)
        
return 
null
;
    
iBodyStart += startString.Length;                           
//第一次字符位置起的长度
    
iBodyEnd = istr.IndexOf(endString, iBodyStart);         
//第二次字符在第一次字符位置起的首次位置
    
if 
(iBodyEnd == -1)
        
return 
null
;
    
iBodyEnd += endString.Length;                              
//第二次字符位置起的长度
    
string 
strResult = istr.Substring(iBodyStart, iBodyEnd - iBodyStart - 1);
    
return 
strResult;
}

 

好了,上面就是全部代码了,如果你想要运行出来的话,有些细节要自己修改下。

你可能感兴趣的文章
hive 动态分区太多问题
查看>>
从Java的角度理解Ext的extend
查看>>
Windows Server 2008 RemoteApp(二)---部署激活远程桌面授权服务器
查看>>
读取日志文件开发总结
查看>>
微星G41TM-P31主板安装centos5.6 x64认不到网卡
查看>>
jdk内部方法获取本机MAC地址
查看>>
Qt学习笔记一:入门
查看>>
VMware Horzion Workspace POC文档—安装3(集成ThinApp,发布应用)
查看>>
在WordPress第一篇文章里添加广告
查看>>
jQuery选择器总结
查看>>
无法加载协定为“WeatherWebServiceSoap”的终结点配置部分,因为找到了该协定的多个终结点配置...
查看>>
活动目录基础
查看>>
IOS --React Native
查看>>
Linux CPU
查看>>
用模板实现顺序表与单链表
查看>>
c++中重载,重写,重定义的区别
查看>>
nagios监控
查看>>
Linux/Centos ntp时间同步,联网情况和无网情况配置
查看>>
初级网络运维工程师比赛题目
查看>>
跨交换机实现vlan实验报告
查看>>