- 在线时间
- 5024 小时
- 最后登录
- 2022-11-28
- 注册时间
- 2009-4-8
- 听众数
- 738
- 收听数
- 1
- 能力
- 23 分
- 体力
- 77392 点
- 威望
- 96 点
- 阅读权限
- 255
- 积分
- 27144
- 相册
- 1
- 日志
- 14
- 记录
- 36
- 帖子
- 4293
- 主题
- 1341
- 精华
- 15
- 分享
- 16
- 好友
- 1975

数学中国总编辑
TA的每日心情 | 衰 2016-11-18 10:46 |
|---|
签到天数: 206 天 [LV.7]常住居民III 超级版主
 群组: 2011年第一期数学建模 群组: 第一期sas基础实训课堂 群组: 第二届数模基础实训 群组: 2012第二期MCM/ICM优秀 群组: MCM优秀论文解析专题 |
万维网过多的信息,股票报价,电影评论,市场价格趋势话题,几乎所有的东西,可以发现在点击一个按钮。在分析数据中发现,许多SAS用户感兴趣在网络上,但你得到这个数据的SAS环境呢?有很多方法,如 SAS数据步骤中的代码在设计你自己的网络爬虫或利用SAS%TMFILTER宏 ® 文本挖掘。在本文中,我们将审查一个网络爬虫的总体架构。我们将讨论获得网站的方法到SAS的信息,以及审查内部所谓的SAS搜索从实验项目的实验代码管道。我们也将提供咨询如何轻松定制一个网络爬虫,以适应个性化需求,以及如何具体的数据导入到SAS ® 企业矿工™。3 `8 d8 ?; ]% A3 T9 e
简介:互联网已经成为一个有用的信息来源。通常是Web上的数据,我们要使用内的SAS,所以我们需要找到一种方式来获得这个数据。最好的办法是使用一个网络爬虫。 SAS提供几个从Web爬行和提取信息的方法。您可以使用基本的SAS数据步骤中的代码,或SAS文本矿工的%TMFILTER宏。虽然目前无法使用,SAS搜索管道将是一个功能强大的Web爬行产品,并提供更多的工具,网络爬行。每种方法都有其优点和缺点,所以取决于你想实现抓取的,它是最好对其进行审查。4 @ F" V. B- i3 a
8 f2 j4 F. b7 h9 j: Y3 S
首先,重要的是要了解网络爬虫是如何工作的。你应该熟悉数据步骤的代码,宏,和SAS过程PROC SQL,然后再继续。
& B4 z" o! p* P: J7 U; ^# H0 X! _1 w网络爬虫概述:一个网络爬虫是一个程序,一个或多个起始地址作为“种子URL”,下载网站这些URL相关的网页,在网页中包含的任何超链接提取,并递归地继续这些超链接标识下载Web页。从概念上讲,网络爬虫是很简单的。
9 Y# T5 |. C. M' d0 U6 w6 W一个Web 履带式有四项职责:/ J+ D n2 W6 k. ^" U. `9 J$ _9 l
1。从候选人中选择一个网址。
" W; e: E* o3 V3 k# \4 |+ R2。它下载相关的Web页。% c% O5 D* m( y/ i" Z( u# T7 _ P, [
3。它提取物在网页中的URL(超链接)。
/ M4 y& Q0 t& N: v2 x4 j7 r4。它补充说,未曾遇到的候选集的URL
6 \# R* }3 o; f- V- |方法1:在WEB SAS数据步骤中的代码履带式
! D! U7 J/ B6 l3 W0 x首先创建一个网址的网站的Web crawler将开始列表。
3 l. M9 k$ ]. Sdata work.links_to_crawl;
' x" |5 i# s, `0 alength url $256 ;' n- E5 O r3 n2 I6 u
input url $;. x$ t+ A4 d/ p" ]" _
datalines;, d+ ?+ }) z8 D1 ]
http://www.yahoo.com( |% F1 Y- E0 y( K" z2 y6 M7 f
http://www.madio.net
/ Z: O+ a# L# J: C9 x2 b3 ohttp://www.google.com- \3 z4 t/ F; y9 ?# {; T' @
;
' b' s- y" G" ]0 W$ x3 drun
* Z$ A$ p! @% D9 Z为了确保我们不抓取相同的URL一次以上,持有环节已创建一个数据抓取。
; q2 g" Z+ y/ p0 _2 R4 Q当Web数据集将在开始时是空的,但一个网站的网址将被添加到数据集履带式完成抓取该网站。* a: Y. k0 y: p
data work.links_crawled; % o; {) p( @4 o7 V& m) ?& f \
length url $256;: V& M+ H; u% Y
run;& B$ O+ U0 N5 c$ k+ u, U
现在我们开始爬行!该代码需要我们的 work.links_to_crawl数据集的第一个URL。在第一观察“_N_式1”,网址是投入名为 next_url 宏变量,所有剩余的URL放回我们的种子URL数据集,使他们在未来的迭代。% f+ a: e4 k) P( x
/* pop the next url off */
& @+ t( p% }- l* t N2 O" H$ m! _%let next_url = ;
9 b: M; ~: k- I) p xdata work.links_to_crawl;
. O" e, X; g) ^8 q6 p8 C0 P. aset work.links_to_crawl;
: w4 X |4 @6 K% ?if _n_ eq 1 then call symput(“next_url”, url);
' P9 r/ A* a1 a- T! A# ?; O. Helse output;
' h9 `+ G3 {1 h% Q! Y* wrun;* T, G2 B- _6 f2 t8 w* c; c! Z, ~
现在,从互联网上下载的网址。创建一个文件名称 _nexturl 。我们让SAS知道它是一个URL 而且可以发现,AT&next_url,这是我们的宏观变量,它包含的网址我们从拉 work.links_to_crawl数据集。( |# e K( f( ]# T3 `+ E1 c
/* crawl the url */
4 l9 h+ w# b7 q0 g; C1 ^% ?filename _nexturl url “&next_url”
! O9 W2 L) U2 P; m建立后的文件名的URL参考,确定一个地方把我们下载的文件。创建另一个文件名引用所谓 htmlfilm的条目,并在那里把从 url_file.html收集到的信息。& U7 n6 S. o5 u# ], z6 r& C
/* put the file we crawled here */! T$ @0 n- E" Q; I- y
filename htmlfile “url_file.html”% W' o7 X; D+ V9 P5 @3 o% i$ P/ J
接下来,我们通过数据的循环,把它写htmlfilm的条目文件名参考,并寻找更多的网址添加到我们的 work.links_to_crawl数据集。8 X- ~" b% A1 M: D8 @4 U# @
/* find more urls */
: ?" A- r2 ^# `# V9 ?/ odata work._urls(keep=url);9 h o, S7 b2 L. o7 I
length url $256 ;! |) k+ s1 O+ S2 F) P3 l
file htmlfile;
# O& w& I! g6 [& J9 Tinfile _nexturl length=len;; a$ \) g& w: }& _( b' s X
input text $varying2000. len;
/ K: w& w" z n/ o6 nput text;7 Y; O$ X% N5 {2 _, s8 y2 _
start = 1;% K* W) C1 U6 T- m9 F( D9 C
stop = length(text);
+ d6 x' T! ]. N, a; w使用正则表达式一个网站的网址,以帮助搜索。正则表达式的匹配方法文本字符串,如字,词,或字符模式。 SAS已经提供了许多强大的字符串功能。然而,正则表达式通常会提供一个更简洁的方式,操纵和匹配的文本.
$ T/ L; F4 x- e6 Q, Z Jif _n_ = 1 then do;
4 A. O) Z1 k7 Y wretain patternID;
" P2 i2 t t3 R' f4 J/ c* I$ ^pattern = ‘/href=”([^"]+)”/i’;+ M0 y! g4 c' o7 b4 T' v) Z# a
patternID = prxparse(pattern);/ j4 z/ t1 W: a D6 z
end; ?* {) D+ ]' ~
首次观察到,创建一个patternID将保持整个数据步运行。寻找的模式是: “/href=”([^"]+)”/i’”.,这意味着我们正在寻找字符串“HREF =”“,然后再寻找任何字符串,是至少有一个字符长,不包含引号(“),并结束在引号(”)。在’我’ 目的的手段使用不区分大小写的方法,以配合我们的正则表达式。
6 h- f; l l. ` u) Q4 j8 J) N- QAs a result, the Web crawler will find these types of strings:
% c' f; V4 K9 ]4 W$ Y6 Jhref=”sgf/2010/papers.html”
) z- h" y, s" [0 X; F( U. ~href=”www.yahoo.com”
' W6 S5 b4 A6 k/ }, p0 J1 \ dHREF=”www.google.com”
1 g; [6 l: k0 b0 S# U. D8 dhReF=”http://www.madio.net”+ @! S% [/ a* _7 d
现在正则表达式匹配的一个网站上的文字。 PRXNEXT需要五个参数:正则表达式我们要寻找,寻找开始寻找正则表达式的开始位置,结束位置停止正则表达式,一旦发现字符串中的位置,而字符串的长度,如果发现的位置将是0,如果没有找到字符串。 PRXNEXT也改变了开始的参数,使搜索重新开始后的最后一场比赛是发现。
; J5 v0 e5 K7 `- scall prxnext(patternID, start, stop, text, position, length);& i2 q2 \ @1 I) R. P8 b; |9 W5 _# G- m
代码中的循环,在网站上找到的所有环节显示的文本。
" W4 s2 s. K: @, @+ K6 Fdo while (position ^= 0);
! g) `: J% D1 J1 ]4 durl = substr(text, position+6, length-7);
_3 @/ h; A% n* qoutput;, [: g" g2 Z7 a* g$ D4 A: I
call prxnext(patternID, start, stop, text, position, length);
1 Y( u7 M; `% r8 ~' Xend;. E I2 q Q9 q$ g
run;1 i7 H: k$ e% R+ W) a3 k! ]8 I
如果代码发现一个网址,它会检索唯一的URL的一部分,启动后的第一个引号。例如,如果代码中发现的HREF =“http://www.new-site.com”,那么它应该保持 http://www.new-site.com 。使用 substr到删除前的6个字符和最后一个字符的URL的其余部分输出的work._urls 数据集。现在,我们插入的URL代码只是以跟踪抓取到一个数据集名为 work.links_crawled 我们已经和确保我们不再次浏览有。 Z1 A9 ~* Q1 L! m6 D
/* add the current link to the list of urls we have already crawled */ + T4 v$ R( T" B1 n4 N: l
data work._old_link;% |- ^- a C4 }" H
url = “&next_url”;" G+ g! Y/ Q1 O- x* l1 H8 e/ L) I
run;
0 U. _* ~' ?9 k6 g) e5 D: Pproc append base=work.links_crawled data=work._old_link force;2 I: p$ u0 M. N6 a0 B
run;3 Z9 |" N" f1 Y( u1 R9 i
下一步是在数据集 work._urls 的过程中发现的网址列表,以确保:
" U( M$ w% N( V: d6 N5 g' W6 S1。我们尚未抓取他们,换句话说URL是不是在 work.links_crawled)。
0 X) c* j6 ]7 E2。我们没有排队抓取的URL(网址换句话说,是不是在work.links_to_crawl )。
+ [( D9 @8 E6 d) F/*6 k9 v7 K$ ^. o1 G5 y$ @ ^
* only add urls that we have not already crawled, s9 a7 Q. f6 e; i# _3 X" ?* B0 g
* or that are not queued up to be crawled
1 W. E7 o$ `" ], N+ p% |*% M) ~! p! {2 K; D* K
*/
8 ^# z' Q) \% t! B5 l! a/ ^proc sql noprint;3 y" z% x2 {( z, D, v8 r& u( J% x
create table work._append as) U5 h; _" a& t! q! r6 E' I
select url
* R3 U4 G$ k- W- ]2 cfrom work._urls1 L: C5 @, e$ m' F g& u
where url not in (select url from work.links_crawled)) H, J2 B- F6 v, n! @1 ]
and url not in (select url from work.links_to_crawl);
6 N2 A- n! q4 ]6 m* w$ V" U2 _quit;* d" Y9 j2 d7 k, Q9 o5 Y- C- t. _
然后,我们添加网址还没有被抓取,而不是已经排队 work.links_to_crawl数据集。
; p( `4 B; p+ k/ [* s, L# U) F$ j/* add new links */3 u5 e4 g; ]5 F% O" _8 J* V
proc append base=work.links_to_crawl data=work._append force;
7 [7 s% D' N+ vrun;6 _; A. k9 O8 D, _- O n/ o4 U
此时的代码循环回到开始劫掠 work.links_to_crawl数据集的下一个URL。6 k$ P& O" E6 a% _ S8 i' ]* T
|
zan
|