数学建模社区-数学中国

标题: 网络爬虫—利用SAS抓取网页方法 [打印本页]

作者: 厚积薄发    时间: 2012-2-27 15:19
标题: 网络爬虫—利用SAS抓取网页方法
万维网过多的信息,股票报价,电影评论,市场价格趋势话题,几乎所有的东西,可以发现在点击一个按钮。在分析数据中发现,许多SAS用户感兴趣在网络上,但你得到这个数据的SAS环境呢?有很多方法,如 SAS数据步骤中的代码在设计你自己的网络爬虫或利用SAS%TMFILTER宏 ® 文本挖掘。在本文中,我们将审查一个网络爬虫的总体架构。我们将讨论获得网站的方法到SAS的信息,以及审查内部所谓的SAS搜索从实验项目的实验代码管道。我们也将提供咨询如何轻松定制一个网络爬虫,以适应个性化需求,以及如何具体的数据导入到SAS ® 企业矿工™。( t( [% }9 B: I/ ?& _* {* k* Q: i
简介:互联网已经成为一个有用的信息来源。通常是Web上的数据,我们要使用内的SAS,所以我们需要找到一种方式来获得这个数据。最好的办法是使用一个网络爬虫。 SAS提供几个从Web爬行和提取信息的方法。您可以使用基本的SAS数据步骤中的代码,或SAS文本矿工的%TMFILTER宏。虽然目前无法使用,SAS搜索管道将是一个功能强大的Web爬行产品,并提供更多的工具,网络爬行。每种方法都有其优点和缺点,所以取决于你想实现抓取的,它是最好对其进行审查。
; e0 p' q0 {* V1 R1 A
( A4 K. G2 F5 R% k. Z% n首先,重要的是要了解网络爬虫是如何工作的。你应该熟悉数据步骤的代码,宏,和SAS过程PROC SQL,然后再继续。
: f- m# E; _9 K2 h网络爬虫概述:一个网络爬虫是一个程序,一个或多个起始地址作为“种子URL”,下载网站这些URL相关的网页,在网页中包含的任何超链接提取,并递归地继​​续这些超链接标识下载Web页。从概念上讲,网络爬虫是很简单的。3 W% Z4 e1 S. @8 q# Z
一个Web 履带式有四项职责:
* e% a4 u  r0 x4 }/ p' h  z1。从候选人中选择一个网址。" Y+ B% p6 l( W
2。它下载相关的Web页。
1 O$ @' K% Z3 P* A: I3。它提取物在网页中的URL(超链接)。2 M0 h/ b7 N7 \3 g1 v
4。它补充说,未曾遇到的候选集的URL* y( }3 Y3 Z9 Q8 Y) G8 ?# q4 }' [
方法1:在WEB SAS数据步骤中的代码履带式
, z8 x' l+ C+ }' U% ~3 N5 w) S2 z首先创建一个网址的网站的Web crawler将开始列表。, e5 B7 F9 Q! H1 B: U
data work.links_to_crawl;" l5 U- a4 a& W1 o% b
length url $256 ;
* Y, l# F0 W# r0 pinput url $;+ Z0 x  M2 N: C7 u
datalines;  m- V- G9 ~7 [1 Z; f( J4 k
http://www.yahoo.com
3 m" F/ k! j& p% T/ }9 H8 }http://www.madio.net9 Z* i3 R/ C, T  c
http://www.google.com
/ V2 X5 S3 g' p7 i. T;8 k( C1 ^2 E/ A5 v3 B
run
. F7 b7 w! g7 q6 p为了确保我们不抓取相同的URL一次以上,持有环节已创建一个数据抓取。
& i, ~1 b9 Q* B1 I% M9 x8 \8 h: g! i! J当Web数据集将在开始时是空的,但一个网站的网址将被添加到数据集履带式完成抓取该网站。
$ {0 I1 v. x2 ~8 ]data work.links_crawled;
6 C# Z* ^; Q$ olength url $256;6 C( o; V( K9 J
run;$ T. J0 d' x% Z4 T) L( L  X) b
现在我们开始爬行!该代码需要我们的 work.links_to_crawl数据集的第一个URL。在第一观察“_N_式1”,网址是投入名为 next_url 宏变量,所有剩余的URL放回我们的种子URL数据集,使他们在未来的迭代。% b# h5 _0 M1 V- F. x
/* pop the next url off */1 b# U; I, m4 T9 ?2 j$ e. w
%let next_url = ;
; e- u5 p' l( ]9 Pdata work.links_to_crawl;- g; I( M, V7 S6 T! a" g/ p$ d
set work.links_to_crawl;) j% [; h4 u, O
if _n_ eq 1 then call symput(“next_url”, url);: f8 C! f. w/ _, s
else output;
5 b" }0 x+ U9 t& u6 `. Drun;9 c  c2 `/ ^- M. f0 U# n; i+ ~) N' b2 E
现在,从互联网上下载的网址。创建一个文件名​​称 _nexturl 。我们让SAS知道它是一个URL 而且可以发现,AT&next_url,这是我们的宏观变量,它包含的网址我们从拉 work.links_to_crawl数据集。/ W/ U; I: C( z: y" N- Y9 c
/* crawl the url */
: ?0 a8 Q; I- qfilename _nexturl url “&next_url”
, J9 _! z# s  w/ _, v建立后的文件名​​的URL参考,确定一个地方把我们下载的文件。创建另一个文件名​​引用所谓 htmlfilm的条目,并在那里把从 url_file.html收集到的信息。
% o9 |# p% f7 d/* put the file we crawled here */5 ]9 Y$ w0 d" H& M8 I1 h
filename htmlfile “url_file.html”
' W! M  `+ _# z( R" l3 b) ^" g4 l- W接下来,我们通过数据的循环,把它写htmlfilm的条目文件名​​参考,并寻找更多的网址添加到我们的 work.links_to_crawl数据集。3 X: U, m- Q5 A8 \, r
/* find more urls */ $ ^6 t+ g+ _& w0 p4 o
data work._urls(keep=url);; I4 _; E+ m( t2 q9 Z
length url $256 ;
1 s- _7 |0 _1 E8 T, Q- l+ ^( Sfile htmlfile;
# O: H& [3 E' q8 `4 Q  O+ X7 X) F% V/ einfile _nexturl length=len;4 W; e! m' ?1 @# P& t
input text $varying2000. len;- ^! B/ q/ C3 w0 @( I4 {
put text;1 X/ K  X; |* B* [! @
start = 1;3 C* V/ K& K2 U9 ?
stop = length(text);
, ^( Q) F* R  c使用正则表达式一个网站的网址,以帮助搜索。正则表达式的匹配方法文本字符串,如字,词,或字符模式。 SAS已经提供了许多强大的字符串功能。然而,正则表达式通常会提供一个更简洁的方式,操纵和匹配的文本.( r, G/ q* B& q1 e
if _n_ = 1 then do;6 I7 P% P2 X( Q# L9 o, ~
retain patternID;
, e; n% R* I$ V) B# Rpattern = ‘/href=”([^"]+)”/i’;
, L" B9 _0 A- O2 NpatternID = prxparse(pattern);
3 H& `7 i5 B1 z7 Y' Y  L7 mend* B) r6 [: B& ?6 N/ z. e9 x
首次观察到,创建一个patternID将保持整个数据步运行。寻找的模式是: “/href=”([^"]+)”/i’”.,这意味着我们正在寻找字符串“HREF =”“,然后再寻找任何字符串,是至少有一个字符长,不包含引号(“),并结束在引号(”)。在’我’ 目的的手段使用不区分大小写的方法,以配合我们的正则表达式。
2 P) Q, Q, A' w" PAs a result, the Web crawler will find these types of strings:
) g2 j! H# w* Q- Nhref=”sgf/2010/papers.html”
6 V7 r8 K; L, g3 z# @% `href=”www.yahoo.com" Z6 `# c/ X; B5 s4 I  k* }
HREF=”www.google.com
0 M, l, ?; O, p, c( d" Z  k2 ShReF=”http://www.madio.net
* h4 f" J" o& G, c5 P+ m" J5 V0 X现在正则表达式匹配的一个网站上的文字。 PRXNEXT需要五个参数:正则表达式我们要寻找,寻找开始寻找正则表达式的开始位置,结束位置停止正则表达式,一旦发现字符串中的位置,而字符串的长度,如果发现的位置将是0,如果没有找到字符串。 PRXNEXT也改变了开始的参数,使搜索重新开始后的最后一场比赛是发现。1 }6 d! R! P' Q, b, u! C! \
call prxnext(patternID, start, stop, text, position, length);
% R4 [& O& l$ }2 C/ |代码中的循环,在网站上找到的所有环节显示的文本。
5 f% ?* E. O) `, V$ Wdo while (position ^= 0);* j/ E, K, {% }) J; E2 e
url = substr(text, position+6, length-7);
. I0 P% D7 t) O3 ^; m8 aoutput;9 [" f! K9 c9 Q
call prxnext(patternID, start, stop, text, position, length);8 s0 W! c0 M7 \0 Z9 _1 W
end;* I! k& `1 e: j4 D
run;
( V3 }4 l2 X  u0 T! _! A8 V如果代码发现一个网址,它会检索唯一的URL的一部分,启动后的第一个引号。例如,如果代码中发现的HREF =“http://www.new-site.com”,那么它应该保持 http://www.new-site.com 。使用 substr到删除前的6个字符和最后一个字符的URL的其余部分输出的work._urls 数据集。现在,我们插入的URL代码只是以跟踪抓取到一个数据集名为 work.links_crawled 我们已经和确保我们不再次浏览有。- n* |( O4 b1 `: B
/* add the current link to the list of urls we have already crawled */
2 v: [2 f6 Z3 Y- c% |( D% y/ Odata work._old_link;9 g9 b1 Q& K: t1 I# N
url = “&next_url”;9 h& r( u0 z- |" N. h
run;
, P1 Z; O7 _- R& |- Y) wproc append base=work.links_crawled data=work._old_link force;
4 Z( v+ W# u! E3 t. prun;* k" \1 R. L7 |9 }& l
下一步是在数据集 work._urls 的过程中发现的网址列表,以确保:
) h  z! t* ?! M8 K  q1。我们尚未抓取他们,换句话说URL是不是在 work.links_crawled)。
& d' u9 M% j( ?: l: L% R* e2。我们没有排队抓取的URL(网址换句话说,是不是在work.links_to_crawl )。( }9 O( I8 i$ a, j" s- `8 r! ?  f
/*
6 t/ y* m7 f5 T0 Z& a* only add urls that we have not already crawled4 P1 B" m) E+ |; s! M+ M( V
* or that are not queued up to be crawled9 [& o" S2 d, J: n' H
*& K" g% K7 t" O, W# s: s7 H. r# k
*/2 i- C( E) v  {. N' F$ M! j
proc sql noprint;
  }5 @3 c# w& ]' u5 Y' @0 z* S% Screate table work._append as
5 \* |9 d9 \' O. M* fselect url7 L) p1 p' I2 u: ^" r4 q( M0 U
from work._urls
% i6 F; ?7 n, D$ B, ^' f; Dwhere url not in (select url from work.links_crawled)
% e" B: f* u. p' [! mand url not in (select url from work.links_to_crawl);9 U% F1 E. v, F+ \$ Z" s
quit;3 }. c$ J; |  d  n. M
然后,我们添加网址还没有被抓取,而不是已经排队 work.links_to_crawl数据集。
+ k6 C3 n% \+ {5 u( Q/* add new links */
' y! |# ]9 y$ o7 Q! t) X1 `proc append base=work.links_to_crawl data=work._append force;6 F; E  h+ h3 B( u
run;' \: Y- c* w  X$ H9 Q+ q( a* J
此时的代码循环回到开始劫掠 work.links_to_crawl数据集的下一个URL。
$ [5 i! W, ~5 ~& ^
作者: 叶纯萱    时间: 2012-3-31 07:04
留个脚印
作者: snowmanPeter    时间: 2014-10-27 11:10
值得一看+ N" U0 C9 [. a, F- S4 F' Z





欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5