Python是Google公司最重要的三大开发语言之一(C++, Java, Python)

用Python语言写搜索引擎蜘蛛的脚本非常简单、轻松。给大家分享两种抓网页内容的方法

一、用urllib2/sgmllib包,将目标网页的所有URL列出。

import urllib2

from sgmllib import SGMLParser

class URLLister(SGMLParser):
    def reset(self):                            
        SGMLParser.reset(self)
        self.urls = []

    def start_a(self, attrs):                    
        href = [v for k, v in attrs if k=='href']
        if href:
            self.urls.extend(href)

f = urllib2.urlopen("http://www.donews.com")

if f.code == 200:
    parser = URLLister()
    parser.feed(f.read())
    f.close()
    for url in parser.urls: print url

二、用python调用IE抓取目标网页(Require win32com, pythoncom)的所有图像的url和大小

import win32com.client, pythoncom
import time

ie = win32com.client.DispatchEx(’InternetExplorer.Application.1′)
ie.Visible = 1
ie.Navigate("http://news.sina.com.cn")
while ie.Busy:
  time.sleep(0.05)

doc = ie.Document
for i in doc.images:
    print i.src, i.width, i.height

这种方法可以利用IE本身的Javascript. DHTML的支持,来做自动提交Form,和处理Javascript。
有关样例可以参考http://win32com.de


4条评论

  1. 看介绍还真的是很简单啊。。

  2. 是pywin32模块的编程么?

    pywin32有什么好的教程么?能不能提供些资料?谢谢了

    andelf@gmail.com

  3. 第一个例子 怎么同时取得链接的名称?

    <a href="http://www.donews.com" target="_blank">Donews首页</a>

    把donews首页也取到记录下来。

发表评论

评论也有版权!