这几天在学习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. AGS Server 10.1 切图工具

    在AGS Sever中很重要的功能就是地图缓存的制作,安装AGS Sever会在catalog中增加相关的工具箱,利用这些工具可以制作.删除.更新切片 一.Convert map server cac ...

  2. JSTL 标签库

    1. JSTL 概述 JSTL 是 apache 对 EL 表达式的扩展, JSTL 是标签语言! 需要导入 jstl-1.2.jar 包 2. JSTL 标签库 core: 核心标签库; fmt: ...

  3. 4.4 使用STM32控制MC20进行GPS帧数据解析

    需要准备的硬件 MC20开发板 1个 https://item.taobao.com/item.htm?id=562661881042 GSM/GPRS天线 1根 https://item.taoba ...

  4. python基础23 -----进程和线程

    一.进程 1.什么是进程? 1.1 进程就是一个程序在一个数据集上的一次动态执行过程.进程一般由程序.数据集.进程控制块三部分组成. 1.2 程序是指进程需要完成那些功能以及如何完成. 1.3 数据集 ...

  5. Binary Search in Java

    关于折半查找中的几个注意点. Version 1: public static <T extends Comparable<? super T>> int binSearch( ...

  6. HDF 文件数据的读取

    http://www.cams.cma.gov.cn/cams_973/cheres_docs/cheres_doc_sat.modis.1b.html一. HDF文件格式 1.概述 HDF 是美国国 ...

  7. docker-compose no such image

    是由于docker-compose旧缓存的问题,执行docker-compose down即可,再重新up

  8. C# Xml Linq XDocument 基本操作 -- 重新学习

    person.xml <?xml version="1.0" encoding="utf-8"?> <MyP> <P1> & ...

  9. C# XMLHttpRequest对象—Ajax实例

    Get: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> ...

  10. matlab 三维绘制

    1. mesh(Z)语句 mesh(Z)语句可以给出矩阵Z元素的三维消隐图,网络表面由Z坐标点定义,与前面叙述的x-y平面的线格相同,图形由邻近的点连接而成.它可用来显示用其它方式难以输出的包含大量数 ...