QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4076|回复: 2
打印 上一主题 下一主题

网络爬虫—利用SAS抓取网页方法

[复制链接]
字体大小: 正常 放大

1341

主题

738

听众

2万

积分

数学中国总编辑

  • TA的每日心情

    2016-11-18 10:46
  • 签到天数: 206 天

    [LV.7]常住居民III

    超级版主

    社区QQ达人 邮箱绑定达人 元老勋章 发帖功臣 新人进步奖 原创写作奖 最具活力勋章 风雨历程奖

    群组2011年第一期数学建模

    群组第一期sas基础实训课堂

    群组第二届数模基础实训

    群组2012第二期MCM/ICM优秀

    群组MCM优秀论文解析专题

    跳转到指定楼层
    1#
    发表于 2012-2-27 15:19 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    万维网过多的信息,股票报价,电影评论,市场价格趋势话题,几乎所有的东西,可以发现在点击一个按钮。在分析数据中发现,许多SAS用户感兴趣在网络上,但你得到这个数据的SAS环境呢?有很多方法,如 SAS数据步骤中的代码在设计你自己的网络爬虫或利用SAS%TMFILTER宏 ® 文本挖掘。在本文中,我们将审查一个网络爬虫的总体架构。我们将讨论获得网站的方法到SAS的信息,以及审查内部所谓的SAS搜索从实验项目的实验代码管道。我们也将提供咨询如何轻松定制一个网络爬虫,以适应个性化需求,以及如何具体的数据导入到SAS ® 企业矿工™。0 A7 v' e' G4 p3 p
    简介:互联网已经成为一个有用的信息来源。通常是Web上的数据,我们要使用内的SAS,所以我们需要找到一种方式来获得这个数据。最好的办法是使用一个网络爬虫。 SAS提供几个从Web爬行和提取信息的方法。您可以使用基本的SAS数据步骤中的代码,或SAS文本矿工的%TMFILTER宏。虽然目前无法使用,SAS搜索管道将是一个功能强大的Web爬行产品,并提供更多的工具,网络爬行。每种方法都有其优点和缺点,所以取决于你想实现抓取的,它是最好对其进行审查。
      A' P: v/ Z. X  t' {
    , J4 D' o5 u/ Z  a* N首先,重要的是要了解网络爬虫是如何工作的。你应该熟悉数据步骤的代码,宏,和SAS过程PROC SQL,然后再继续。
    ' y" d9 e) U' E3 o2 O+ ?网络爬虫概述:一个网络爬虫是一个程序,一个或多个起始地址作为“种子URL”,下载网站这些URL相关的网页,在网页中包含的任何超链接提取,并递归地继​​续这些超链接标识下载Web页。从概念上讲,网络爬虫是很简单的。
      i4 u7 @; ~, `6 t1 ?- A; ]/ ~一个Web 履带式有四项职责:
    - t- x. g- q! s* R+ I$ Z1。从候选人中选择一个网址。
    ( I/ A7 j( b% w0 N: ~2。它下载相关的Web页。) H) c; T3 p& u5 ]
    3。它提取物在网页中的URL(超链接)。2 Y+ M$ U) R. V6 V; F
    4。它补充说,未曾遇到的候选集的URL
    ; f9 I. t1 j: L0 u5 x( _7 e方法1:在WEB SAS数据步骤中的代码履带式
    % i! q2 B1 a' N' @% F/ |首先创建一个网址的网站的Web crawler将开始列表。4 b- ^9 g4 J( [5 d. L# j; F9 Z; W( {9 n
    data work.links_to_crawl;" C5 C  ?4 J2 b$ _; g
    length url $256 ;
    & U) u$ Y! r' X; W1 p$ `input url $;
    5 C1 E& t* b" w5 a/ o! |: ]datalines;9 B- H& q5 {2 c' i+ M
    http://www.yahoo.com
    7 g0 O: Y; j: J1 [6 \7 i+ F1 T: ?& thttp://www.madio.net$ E4 ^7 ^+ g' ]. y+ ]: }
    http://www.google.com
    & T0 j- G6 a& m* h  F, S" z;
    2 B- S9 P2 W% u- v$ Q7 `1 drun8 I& F# }9 I% ^0 l/ N
    为了确保我们不抓取相同的URL一次以上,持有环节已创建一个数据抓取。. |/ u5 o/ G6 p- a2 U( V+ j- F
    当Web数据集将在开始时是空的,但一个网站的网址将被添加到数据集履带式完成抓取该网站。
    1 y/ E. X/ j7 ~5 cdata work.links_crawled; ; o6 @. K. ~, f/ u4 v8 u  o$ G, ~
    length url $256;$ x) D& e$ a* m) ?8 z
    run;( B: v5 c8 g2 k# R1 p
    现在我们开始爬行!该代码需要我们的 work.links_to_crawl数据集的第一个URL。在第一观察“_N_式1”,网址是投入名为 next_url 宏变量,所有剩余的URL放回我们的种子URL数据集,使他们在未来的迭代。5 l9 u) K1 |# g& ]
    /* pop the next url off */
    ( }; H, y" i0 S1 k' h' i6 }$ z%let next_url = ;/ |4 G. a# q' Z( c. P6 I
    data work.links_to_crawl;' C! e+ t* Q; F
    set work.links_to_crawl;
    ! f3 w. h2 V$ y: w5 vif _n_ eq 1 then call symput(“next_url”, url);
    - ~7 o5 X; M' g- r) E% v& [, D; s/ k1 Z; Qelse output;) h  o; A/ J9 \+ `; Q7 C' S: c
    run;
    $ \5 ~4 i/ U3 V( v/ r% w现在,从互联网上下载的网址。创建一个文件名​​称 _nexturl 。我们让SAS知道它是一个URL 而且可以发现,AT&next_url,这是我们的宏观变量,它包含的网址我们从拉 work.links_to_crawl数据集。
    $ N- h5 a+ }9 p0 J/* crawl the url */- c- _; Y  U: P
    filename _nexturl url “&next_url”: f4 s) |, ]0 K
    建立后的文件名​​的URL参考,确定一个地方把我们下载的文件。创建另一个文件名​​引用所谓 htmlfilm的条目,并在那里把从 url_file.html收集到的信息。
    4 J9 q; r0 T# }2 u  I0 g! {& S3 k3 M/* put the file we crawled here */
    6 @$ X" u7 y3 Hfilename htmlfile “url_file.html”0 m% }3 Z; g8 L9 g: l
    接下来,我们通过数据的循环,把它写htmlfilm的条目文件名​​参考,并寻找更多的网址添加到我们的 work.links_to_crawl数据集。1 [# m. U& k3 N5 o9 u
    /* find more urls */ + c+ U, L: B; }; L% C4 ]
    data work._urls(keep=url);7 r1 h5 W$ [+ w: ^4 {; R
    length url $256 ;
    % }$ N! a6 s- L# Jfile htmlfile;* C8 @+ q( O. _& m
    infile _nexturl length=len;
    " C% k5 H7 _" I0 [! E6 Tinput text $varying2000. len;, ^. d; E) Y8 _; q" n- g# j- E
    put text;
    ; Y5 {' K* y4 \) b7 O5 Hstart = 1;% L: o9 V3 T) c8 J" e  P
    stop = length(text);
    " I/ ]5 ?/ l' K; n7 H1 P使用正则表达式一个网站的网址,以帮助搜索。正则表达式的匹配方法文本字符串,如字,词,或字符模式。 SAS已经提供了许多强大的字符串功能。然而,正则表达式通常会提供一个更简洁的方式,操纵和匹配的文本.- k9 `5 `3 u" z2 A" j) w7 I
    if _n_ = 1 then do;6 Z: u$ @$ _+ E9 }* o
    retain patternID;
    ! P' Z8 ^0 d/ U: vpattern = ‘/href=”([^"]+)”/i’;: R. F. q  z# Z# W# P1 }
    patternID = prxparse(pattern);8 O; Y: N3 P- V. b2 [
    end9 D6 C) d( W( A8 H: J
    首次观察到,创建一个patternID将保持整个数据步运行。寻找的模式是: “/href=”([^"]+)”/i’”.,这意味着我们正在寻找字符串“HREF =”“,然后再寻找任何字符串,是至少有一个字符长,不包含引号(“),并结束在引号(”)。在’我’ 目的的手段使用不区分大小写的方法,以配合我们的正则表达式。# k) c) h0 d3 f2 `/ k( o, ]
    As a result, the Web crawler will find these types of strings:2 C8 S/ }7 j  g
    href=”sgf/2010/papers.html”
    8 Q# g$ l6 H+ Y/ Fhref=”www.yahoo.com
    , P% _% @: {, ]3 ~# T2 ]HREF=”www.google.com
    % T. n9 e5 o1 Z8 N9 thReF=”http://www.madio.net" E9 j+ {1 ?3 U# j
    现在正则表达式匹配的一个网站上的文字。 PRXNEXT需要五个参数:正则表达式我们要寻找,寻找开始寻找正则表达式的开始位置,结束位置停止正则表达式,一旦发现字符串中的位置,而字符串的长度,如果发现的位置将是0,如果没有找到字符串。 PRXNEXT也改变了开始的参数,使搜索重新开始后的最后一场比赛是发现。
    6 q/ o) _* n3 ~call prxnext(patternID, start, stop, text, position, length);- D+ t  A% ?: m% w* }1 W' d
    代码中的循环,在网站上找到的所有环节显示的文本。" [0 e) k8 L; k+ U0 ?) b
    do while (position ^= 0);
    ' ?( H9 @: ?; r6 j# B/ Durl = substr(text, position+6, length-7);6 L9 c( y+ P* k2 |" b& n6 l
    output;
    9 t+ W* u9 y% W' m6 F) `call prxnext(patternID, start, stop, text, position, length);
    4 n: q: p) Q8 W( w. v# _end;
    2 A7 y; N) D: U4 }6 }& Zrun;) B# ~( N4 q7 h2 n) P
    如果代码发现一个网址,它会检索唯一的URL的一部分,启动后的第一个引号。例如,如果代码中发现的HREF =“http://www.new-site.com”,那么它应该保持 http://www.new-site.com 。使用 substr到删除前的6个字符和最后一个字符的URL的其余部分输出的work._urls 数据集。现在,我们插入的URL代码只是以跟踪抓取到一个数据集名为 work.links_crawled 我们已经和确保我们不再次浏览有。
    # L5 V0 p. C) d" G/* add the current link to the list of urls we have already crawled */
    % U. Z, P2 _, g  h9 U" ydata work._old_link;% [' t7 T* ]& ^$ [8 w* t! C: q1 u
    url = “&next_url”;
    % e/ `9 E- e4 P* n5 y; o# d) ?run;, T7 ?4 Y3 H4 w/ t# E8 L- i
    proc append base=work.links_crawled data=work._old_link force;% |6 \1 y  D& l3 }" D8 _
    run;
    9 z) _: k' g  s! \! W* z下一步是在数据集 work._urls 的过程中发现的网址列表,以确保:
    , ]1 h* N& T0 Y. N' k, E4 Y1。我们尚未抓取他们,换句话说URL是不是在 work.links_crawled)。  @* m6 k8 t: i. @
    2。我们没有排队抓取的URL(网址换句话说,是不是在work.links_to_crawl )。, d) H! s& H4 k
    /*7 q8 i1 I8 W4 F- Q
    * only add urls that we have not already crawled% c( S! Y3 [- D- q; S
    * or that are not queued up to be crawled1 |+ Q) b4 \4 U/ C
    *7 v) C& p+ z$ {5 o$ P9 C0 y3 ?
    */
    9 S- \/ m" D, q2 V# h0 F2 Q. ~proc sql noprint;. w' E9 c7 @: x9 m: }( v/ F# _
    create table work._append as
    6 C6 F0 ?) Y4 yselect url
    # s9 Z; e/ Q7 {  M+ l$ ^from work._urls
    9 `  d9 i* N8 e# B6 V3 S1 r1 ewhere url not in (select url from work.links_crawled)
    $ I  h' M7 `% I, Xand url not in (select url from work.links_to_crawl);
    6 }# Y0 K2 |) I. m) Wquit;
      C% T, _1 @, E  J然后,我们添加网址还没有被抓取,而不是已经排队 work.links_to_crawl数据集。' E. d0 G( U  O
    /* add new links */
    , q  _7 ^9 n: D( }( h& W8 H8 \proc append base=work.links_to_crawl data=work._append force;$ e" o( V& E5 T% [1 d
    run;" o: h: `7 O* J
    此时的代码循环回到开始劫掠 work.links_to_crawl数据集的下一个URL。7 k9 J0 a+ G- L  r) b
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    叶纯萱 实名认证       

    2

    主题

    3

    听众

    107

    积分

    升级  3.5%

  • TA的每日心情
    开心
    2012-5-6 09:13
  • 签到天数: 34 天

    [LV.5]常住居民I

    群组数学专业考研加油站

    群组Matlab讨论组

    群组C 语言讨论组

    群组Linux推广

    群组EXCEL

    回复

    使用道具 举报

    0

    主题

    4

    听众

    35

    积分

    升级  31.58%

  • TA的每日心情
    开心
    2015-7-2 14:33
  • 签到天数: 11 天

    [LV.3]偶尔看看II

    自我介绍
    我是来自浙江工业大学的学生

    群组数学建模培训课堂1

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-18 06:11 , Processed in 0.473197 second(s), 67 queries .

    回顶部