这几天在学习selenium,顺便用selenium + python写了一个比较简陋的爬虫,现附上源码,有时间再补充补充:

 from selenium import webdriver
 from selenium.webdriver.support.wait import WebDriverWait
 from selenium.webdriver.support import expected_conditions as EC
 from selenium.webdriver.common.by import By
 import os

 class DouBan_Movies:

     def __init__(self):
         #初始化chromedriver
         self.driver = webdriver.Chrome()
         #调用函数进入豆瓣电影top250官网
         self.__enter_douban()
         #在当前目录下建一个文本文件用来写入电影信息
         self.fs = open(os.getcwd() + r"\douban_top250.txt", "w+", encoding="utf-8")

     def __enter_douban(self):
         #打开百度首页
         self.driver.get("http://www.baidu.com")
         #窗口最大化
         self.driver.maximize_window()
         #百度首页输入框的元素表达式
         input_id = "kw"
         #设置显性等待,等待百度首页输出框的出现
         WebDriverWait(self.driver, 3, 0.3).until(EC.visibility_of_element_located((By.ID, input_id)))
         #定位百度输入框并输入豆瓣电影Top250
         self.driver.find_element_by_id(input_id).send_keys("豆瓣电影Top250")
         #定位百度一下按钮并点击
         self.driver.find_element_by_id("su").click()
         #第一条搜索结果的元素表达式
         top250_css = "div[id='1'] h3 a"
         #设置显性等待,等待第一条搜索结果的出现
         WebDriverWait(self.driver, 5, 0.3).until(EC.visibility_of_element_located((By.CSS_SELECTOR, top250_css)))
         #获得当前浏览器的所有窗口句柄
         windows = self.driver.window_handles
         #定位到第一条搜索结果并点击
         self.driver.find_element_by_css_selector(top250_css).click()
         #设置显性等待,等待新窗口的出现
         WebDriverWait(self.driver, 10, 0.3).until(EC.new_window_is_opened(windows))
         #获得当前浏览器的所有窗口句柄
         windows = self.driver.window_handles
         #切换到新的窗口
         self.driver.switch_to.window(windows[-1])

     def __get_datas(self):
         if self.page_num == 1:
             #得到标题
             title = self.driver.find_element_by_xpath("//div[@id='content']//h1").text
             #打印标题
             print(title)
             self.fs.write(title + "\r\n")
         #获得当前页面电影信息的元素对象的列表,总共有25条
         movies_list = self.driver.find_elements_by_xpath("//ol//li")
         for element in movies_list:
             print(element.text + "\n")
             self.fs.write(element.text + "\r\n")

     def get_all_pages(self):
         self.page_num = 1
         while self.page_num < 26:
             self.__get_datas()
             print("-------------第{0}页-----------\n".format(self.page_num))
             self.fs.write("-------------第{0}页-----------\n".format(self.page_num))
             self.page_num += 1
         #关闭文件
         self.fs.close()

 douban_movies = DouBan_Movies()
 douban_movies.get_all_pages()

控制台输出

保存到文件

利用selenium爬取豆瓣电影Top250的更多相关文章

  1. scrapy框架 + selenium 爬取豆瓣电影top250......

    废话不说,直接上代码..... 目录结构 items.py import scrapy class DoubanCrawlerItem(scrapy.Item): # 电影名称 movieName = ...

  2. urllib+BeautifulSoup无登录模式爬取豆瓣电影Top250

    对于简单的爬虫任务,尤其对于初学者,urllib+BeautifulSoup足以满足大部分的任务. 1.urllib是Python3自带的库,不需要安装,但是BeautifulSoup却是需要安装的. ...

  3. python2.7爬取豆瓣电影top250并写入到TXT,Excel,MySQL数据库

    python2.7爬取豆瓣电影top250并分别写入到TXT,Excel,MySQL数据库 1.任务 爬取豆瓣电影top250 以txt文件保存 以Excel文档保存 将数据录入数据库 2.分析 电影 ...

  4. scrapy爬虫框架教程(二)-- 爬取豆瓣电影TOP250

    scrapy爬虫框架教程(二)-- 爬取豆瓣电影TOP250 前言 经过上一篇教程我们已经大致了解了Scrapy的基本情况,并写了一个简单的小demo.这次我会以爬取豆瓣电影TOP250为例进一步为大 ...

  5. scrapy爬取豆瓣电影top250

    # -*- coding: utf-8 -*- # scrapy爬取豆瓣电影top250 import scrapy from douban.items import DoubanItem class ...

  6. 一起学爬虫——通过爬取豆瓣电影top250学习requests库的使用

    学习一门技术最快的方式是做项目,在做项目的过程中对相关的技术查漏补缺. 本文通过爬取豆瓣top250电影学习python requests的使用. 1.准备工作 在pycharm中安装request库 ...

  7. python 爬虫&爬取豆瓣电影top250

    爬取豆瓣电影top250from urllib.request import * #导入所有的request,urllib相当于一个文件夹,用到它里面的方法requestfrom lxml impor ...

  8. 【转】爬取豆瓣电影top250提取电影分类进行数据分析

    一.爬取网页,获取需要内容 我们今天要爬取的是豆瓣电影top250页面如下所示: 我们需要的是里面的电影分类,通过查看源代码观察可以分析出我们需要的东西.直接进入主题吧! 知道我们需要的内容在哪里了, ...

  9. Scrapy中用xpath/css爬取豆瓣电影Top250:解决403HTTP status code is not handled or not allowed

    好吧,我又开始折腾豆瓣电影top250了,只是想试试各种方法,看看哪一种的方法效率是最好的,一直进行到这一步才知道 scrapy的强大,尤其是和selector结合之后,速度飞起.... 下面我就采用 ...

随机推荐

  1. Vue中获取dom元素

    Vue.js虽然说是数据驱动页面的,但是有时候我们也要获取dom对象进行一些操作. vue的不同版本获取dom对象的方法不一样 Vue.js  1.0版本中,通过v-el绑定,然后通过this.els ...

  2. python模块学习(二)

    configparser模块 软件常见文档格式如下: [DEFAULT]ServerAliveInterval = 45Compression = yesCompressionLevel = 9For ...

  3. 卷积神经网络(CNN)的训练及代码实现

    本文部分内容来自zouxy09的博客.谢谢.http://blog.csdn.net/zouxy09/article/details/9993371 以及斯坦福大学深度学习教程:http://ufld ...

  4. when you are old

    When you are old william Butler Yeats When you are old and grey and full of sleep And nodding by the ...

  5. classmethod和staticmethod区别

    实例方法:在类中,定义的方法,这个方法的第一个参数默认是实例对象,一般习惯使用self 类方法:在类中,定义的方法,这个方法的第一个参数默认是类对象,一般习惯用cls表示,用@classmethod装 ...

  6. smarty模板及其应用

    Smarty是一个使用PHP写出来的模板引擎,是目前业界最著名的PHP模板引擎之一.它分离了逻辑代码和外在的内容,提供了一种易于管理和使用的方法,用来将原本与HTML代码混杂在一起PHP代码逻辑分离. ...

  7. 在vim下按ctrl+s后界面卡住

    用惯了window编辑器的我们,在使用linux vim编辑器时会不会遇到这个问题:在编辑时总是会不小心按下Ctrl+S,然后整个终端都没有反应了?其实在Linux下 Ctrl+S是有特殊的用途的,不 ...

  8. SQL性能调优策略

    1.建立索引 2.避免全表扫描 避免使用is null, is not null,这样写会放弃该字段的索引. 如果会出现这种情况,尽量在设计表的时候设置默认值 比较操作符中!= <>等避免 ...

  9. k-近邻算法 标签分类

    k-近邻算法根据特征比较,然后提取样本集中特征最相似数据(最邻近)的分类标签.那么,如何进行比较呢? 怎么判断红色圆点标记的电影所属的类别呢? 如下图所示. 答:距离度量.这个电影分类的例子有2个特征 ...

  10. [Android]开源中国源码分析之二---DrawerLayout

    从启动界面到主界面之后的效果如图所示,采用的是v4包下的DrawerLayout, activity_main.xml文件如下: <!-- A DrawerLayout is intended ...