pyppeteer的使用

安装

  • 属于第三方模块进行安装. pip install pyppeteer

  • 在Linux中,如果权限不够则加上. sudo pip install pyppeteer

使用

使用今日头条作为demo

from pyppeteer import launch
import asyncio

async def main(timeout=30):# 设定时间超时, 默认是30秒
   # async 用来申明一个函数是一个异步函数
   browser = await launch(headless=True, args=["--no-sandbox"])
   # 参数说明:
   # headless 参数设为False,变为有头模式
   # Pyppeteer 支持字典和关键字传递参数
   page = await browser.newPage()
   
   # 设置页面大小
   await page.setViewport(viewport={"width":1280, "height":800})
   
   # 是否启用JS, enabled设为False,则无渲染效果
   await page.setJavaScriptEnabled(enabled=True)
   
   # 超时时间设置
   res = await page.goto(url=url, options={"timeout":1000})
   # 响应头
   resp_headers = res.headers
   # 响应状态
   resp_status = res.status
   
   # 等待
   await asynico.sleep(2)
   # 第二种方法
   while not await page.querySelector(".t"):
       pass
   
   # 滚动到页面底部
   await page.evaluate('windows.scrollBy(0,document.body.scrollHeight)')
   
   # 截图报存图片
   await page.screenshot({"path": "toutiao.png"})
   
   # 获取cookie
   print(await page.cookies())  
   
   # 打印页面文本信息
   print(await page.content())
   
   # 在页面上执行js脚本
   dimensions = await page.evaluate(pageFunction='''() => {
          return {
              width: document.documentElement.clientWidth, // 页面宽度
              height: document.documentElement.clientHeight, // 页面高度
              deviceScaleFactor: window.devicePixelRatio, // 像素比 1.0000000149011612
          }
      }''', force_expr=False)  # force_expr=False 执行的是函数
   print(dimensions)
   # 只获取文本 执行 js 脚本 force_expr 为 True 则执行的是表达式
   content = await page.evaluate(pageFunction='document.body.textContent', force_expr=True)
   print(content)

   # 打印当前页标题
   print(await page.title())\
   
   # 抓取其他信息
   """
  1.选择器, Page.querySelector()
  2.选择器, Page.querySelectorAll()
  3.xpath表达式, Page.xpath()
  """
   # 使用querySelector()
   element = await page.querySelector(".feed-infinite-wrapper > ul>li") # 只抓取一个
   print(element)
   
   # 获取所有的文本信息, 执行js代码
   content = await page.querySelectorAll('(element) => element.textContent', element)
   print(content)
   
   # 使用xpath
   # elements = await page.xpath('//div[@class="title-box"]/a')
   # 使用选择器全选
   elements = await page.querySelectorAll(".title-box a")
   for item in elements:
       print(await item.getProperty("textContent"))
       # 获取文本信息
       title = await (await item.getProperty("textContent")).jsonValue()
       # 获取连接
       link = await (await item.getProperty("href")).jsonValue()
       print(title)  
       print(link)
   # 关闭浏览器
   await browser.close()  
  • 如何启动程序

  • 1.创建一个event_loop对象

       loop = asyncio.get_event_loop()
  • 2.启动运行

       loop.run_until_complete(main())

模拟键盘输入

# 模拟输入 账号密码  {'delay': rand_int()} 为输入时间
   await page.type('#TPL_username_1', "sadfasdfasdf")
   await page.type('#TPL_password_1', "123456789", )
   
   await page.waitFor(1000)
   await page.click("#J_SubmitStatic")
使用tkinter获取页面高度宽度
def screen_size():
   """使用tkinter获取屏幕大小"""
   import tkinter
   tk = tkinter.Tk()
   width = tk.winfo_screenwidth()
   height = tk.winfo_screenheight()
   tk.quit()
   return width, height
针对iframe操作
  • page.frames获取所有的iframe列表,需要判断操作的是哪一个iframe跟操作page一样

from pyppeteer import launch
import asyncio

async def main(url):
   w = await launch({"headless":False, "args":["--no-sandbox"]})
   page = await w.newPage()
   await page.setViewport({"width":1366, "height":800})
   await page.goto(url)
   try:
       await asyncio.sleep(1)
       frame = page.frames
       print(frame)
       
       title = await frame[1].title()
       print(title)
       
       await asyncio.sleep(1)
       login = await frame[1].querySelector('#switcher_plogin')
       print(login)
       
       await login.click()
       await asyncio.sleep(5)
   except Exception as e:
       print(e)
   for page in await w.pages():
       await page.close()
   await w.close()

asyncio.get_event_loop().run_until_complete(main("https://i.qq.com/?rd=1"))
# asyncio.get_event_loop().run_until_complete(main("https://www.gushici.com/"))

大部分借鉴与别人,目前觉得模拟器爬虫还是比较慢的,静待大家的创新。

pyppeteer的使用的更多相关文章

  1. pyppeteer(python版puppeteer)基本使用

    一.前言 以前使用selenium的无头浏览器,自从phantomjs2016后慢慢不更新了之后,selenium也开始找下家,这时候谷歌的chrome率先搞出来无头浏览器并开放了各种api,随后fi ...

  2. pyppeteer 报错-无法连接到浏览器

    问题 程序报错: Failed to connect to browser port: http://127.0.0.1:57899/json/version 原因 虽然pyppeteer在首次启动时 ...

  3. pyppeteer爬虫例子

    如果在centos上使用,需要安装下面的依赖 yum install pango.x86_64 libXcomposite.x86_64 libXcursor.x86_64 libXdamage.x8 ...

  4. pyppeteer使用笔记

    pyppeteer -- python版本的puppeteer,一个强大的chronium headless浏览器API 最近搞天猫用了一波儿,记录一下. 先上文档: https://miyakogi ...

  5. pyppeteer初尝滋味

    最近在爬几个电商平台网站用的selenium一登录就会有验证,目前这些网站对selenium检测很严格 因为不少大网站有对selenium的js监测机制.比如navigator.webdriver,n ...

  6. 网络爬虫之使用pyppeteer替代selenium完美绕过webdriver检测

    1引言 曾经使用模拟浏览器操作(selenium + webdriver)来写爬虫,但是稍微有点反爬的网站都会对selenium和webdriver进行识别,网站只需要在前端js添加一下判断脚本,很容 ...

  7. Pyppeteer

    pyppeteer模块的基本使用 引言 Selenium 在被使用的时候有个麻烦事,就是环境的相关配置,得安装好相关浏览器,比如 Chrome.Firefox 等等,然后还要到官方网站去下载对应的驱动 ...

  8. pyppeteer进阶技巧

    记录一下在使用pyppeteer过程中慢慢发现的一些稍微高级一点的用法. 一.拦截器简单用法 拦截器作用于单个Page,即浏览器中的一个标签页.每初始化一个Page都要添加一下拦截器.拦截器实际上是 ...

  9. 爬虫的新模块pyppeteer的使用

    安装 python3 -m pip install pyppeteer 最好是py3.5+ 手动安装 你懂的,天朝网络环境很复杂,如果要用pyppeteer自己绑定的chromium,半天都下载不下来 ...

随机推荐

  1. springboot管理类,springboot注入类

    springboot管理类,springboot注入类 定义一个配置类,添加@Configuration注解,EvaluatorTemplate代表你需要注入的第三方类 @Configuration ...

  2. 如何创建Github创库

    重点:利用Markdown语言写简单的日常使用的文本 基础写作和语法格式 本篇文章的内容来源于Github的基础写作帮助.如果在观看时有什么问题,可以直接查阅源文件.另外需要说明的是Git对Markd ...

  3. 第十五章 LVM管理和ssm存储管理器使用 随堂笔记

    第十五章 LVM管理和ssm存储管理器使用 本节所讲内容: 15.1 LVM的工作原理 15.2 创建LVM的基本步骤 15.3 实战-使用SSM工具为公司的邮件服务器创建可动态扩容的存储池 LVM的 ...

  4. 关于asp.net调用gemalto超级狗api的具体实现

    鉴于网上关于超级狗的具体操作并不详细,我把我所知道的写下来,希望能给有需求的网友做个参考.软件外壳保护我就不说了,没有什么难度,供应商也会提供文档,一步一步操作即可.我要说的是用于保护发给客户的程序, ...

  5. Activiti 开发案例之动态指派任务

    流程图 以上是一个请假的流程图,以下为流程任务节点描述: 员工发起请假流程 部门经理审批 同意则进入人事审批 拒绝则调整申请或者直接结束流程 人事审批通过则进入销假环节 人事审批拒绝则调整申请或者直接 ...

  6. vue过滤器的使用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. 使用 .NET CORE 创建 项目模板,模板项目,Template

    场景:日常工作中,你可能会碰到需要新建一个全新的解决方案的情况(如公司新起了一个新项目,需要有全新配套的后台程序),如果公司内部基础框架较多.解决方案需要DDD模式等,那么从新起项目到各种依赖引用到能 ...

  8. 一个有趣的 5 X 5 方阵一笔画问题

      这个问题是在我上小学时同学告诉我的,当时觉得好玩,就随便瞎画这玩儿,不过从小学到大学,没有一次画成功过.这个问题起初同学告诉我的时候,图不是这样画的,我只是为了好表达,将问题抽象成网格了,原问题是 ...

  9. 拼写单词[哈希表]----leetcode周赛150_1001

    题目描述: 给你一份『词汇表』(字符串数组) words 和一张『字母表』(字符串) chars. 假如你可以用 chars 中的『字母』(字符)拼写出 words 中的某个『单词』(字符串),那么我 ...

  10. 源码分析Retrofit请求流程

    Retrofit 是 square 公司的另一款广泛流行的网络请求框架.前面的一篇文章<源码分析OKHttp执行过程>已经对 OkHttp 网络请求框架有一个大概的了解.今天同样地对 Re ...