军工 發表於 2020-12-18 14:03:00

推荐一款最强Python自动化神器!不用写一行代码!

<p><img src="https://tva1.sinaimg.cn/large/0081Kckwgy1glokywezeaj30u00dgmxl.jpg" alt="" loading="lazy"></p>
<p>搞过自动化测试的小伙伴,相信都知道,在Web自动化测试中,有一款自动化测试神器工具: <code>selenium</code>。结合标准的WebDriver API来编写Python自动化脚本,可以实现解放双手,让脚本代替人工在Web浏览器上完成指定的操作。</p>
<p>虽然<code>selenium</code>有完备的文档,但也需要一定的学习成本,对于一个纯小白来讲还是有些门槛的。</p>
<p>最近,<strong>微软开源</strong>了一个非常强大的自动化项目叫<strong>「playwright-python」</strong>,项目地址:</p>
<pre><code class="language-python">https://github.com/microsoft/playwright-python
</code></pre>
<p>它支持主流的浏览器,包含:<code>Chrome</code>、<code>Firefox</code>、<code>Safari</code>、<code>Microsoft Edge</code> 等,同时支持以<strong>无头模式</strong>、<strong>有头模式运行</strong>,并提供了<code>同步</code>、<code>异步</code>的 API,可以结合 <code>Pytest</code> 测试框架使用,并且支持浏览器端的自动化脚本录制。</p>
<p>而对于Python爱好者来说,还有一个更大的福利,这个项目是针对Python语言的纯自动化工具,<strong>可以做到,连一行代码都不用写,就能实现自动化功能</strong>。听起来,简直太碉堡了!</p>
<p><img src="https://tva1.sinaimg.cn/large/0081Kckwgy1glokzjmfhbj30a008ogmg.jpg" alt="" loading="lazy"></p>
<p>可能你会觉得有点不可思议,真的不用写一行代码吗?但它真的就是这么厉害。下面我们一起看下这个神器。</p>
<h2 id="1-playwright介绍"><strong>1.</strong> Playwright介绍</h2>
<p>Playwright是一个强大的Python库,仅用一个API即可自动执行<code>Chromium</code>、<code>Firefox</code>、<code>WebKit</code>等主流浏览器自动化操作,并同时支持以<strong>无头模式</strong>、<strong>有头模式</strong>运行。</p>
<p>Playwright提供的自动化技术是绿色的、功能强大、可靠且快速,支持<code>Linux</code>、<code>Mac</code>以及<code>Windows</code>操作系统。</p>
<p><img src="https://tva1.sinaimg.cn/large/0081Kckwgy1glom60ty7aj31aq0q8dka.jpg" alt="" loading="lazy"></p>
<p><strong>官网:</strong></p>
<pre><code>https://playwright.dev/
</code></pre>
<p><img src="https://tva1.sinaimg.cn/large/0081Kckwgy1glolzgfopyj31mb0u0dm9.jpg" alt="" loading="lazy"></p>
<p>从官网上来看,官方给<code>Playwright</code>定位是一款真正意义上的Web端到端测试工具。</p>
<h2 id="2-playwright使用"><strong>2.</strong> Playwright使用</h2>
<h4 id="21-安装">2.1 安装</h4>
<p>Playwright功能强大,但它的安装步骤,非常简单,只需要 2 步:</p>
<p><strong>第 1 步,安装 playwright-python 依赖库</strong> (需要注意的是,playwright库需要依赖Python3.7+以上)</p>
<pre><code class="language-python"># 安装依赖库

➜~ pip3 install playwright
Looking in indexes: https://pypi.douban.com/simple
Collecting playwright
Downloading https://pypi.doubanio.com/packages/08/f0/9f937ccff3221685d4a8bd406649c85855b9b6a2fafe75920b02151b48e0/playwright-0.162.2-py3-none-macosx_10_13_x86_64.whl (58.2 MB)
   |████████████████████████████████| 58.2 MB 1.6 MB/s
Collecting greenlet==1.0a1
Downloading https://pypi.doubanio.com/packages/aa/74/6e93515873829a8d894863bbae1d709405bdd50d66fdf239480cc9db0598/greenlet-1.0a1-cp38-cp38-macosx_10_9_x86_64.whl (86 kB)
   |████████████████████████████████| 86 kB 6.9 MB/s
Collecting typing-extensions
Downloading https://pypi.doubanio.com/packages/60/7a/e881b5abb54db0e6e671ab088d079c57ce54e8a01a3ca443f561ccadb37e/typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)
Collecting pyee&gt;=8.0.1
Downloading https://pypi.doubanio.com/packages/0d/0a/933b3931107e1da186963fd9bb9bceb9a613cff034cb0fb3b0c61003f357/pyee-8.1.0-py2.py3-none-any.whl (12 kB)
Installing collected packages: greenlet, typing-extensions, pyee, playwright
Successfully installed greenlet-1.0a1 playwright-0.162.2 pyee-8.1.0 typing-extensions-3.7.4.3
</code></pre>
<p>可以在<code>https://pypi.org/project/playwright/</code>查看它的依赖版本信息。</p>
<p><strong>第 2 步,安装主流的浏览器驱动</strong></p>
<p>这样,会将 Chromeium、Firefox、Webkit 浏览器驱动下载到本地</p>
<pre><code># 安装浏览器驱动(安装过程稍微有点慢,请耐心等待)
➜~ python3 -m playwright install
Downloading chromium v827102 - 121.3 Mb [====================] 100% 0.0s
chromium v827102 downloaded to /Users/xxx/Library/Caches/ms-playwright/chromium-827102
Downloading firefox v1205 - 74.1 Mb [                  ] 1% 37767.9s
</code></pre>
<p>3.<strong>如果想查看<code>Playwright</code>支持的功能</strong>, 可以直接在命令行输入:</p>
<pre><code class="language-python">➜~ python3 -m playwright help
Usage: index

Options:
-V, --version                        output the version number
-b, --browser &lt;browserType&gt;            browser to use, one of cr, chromium, ff, firefox, wk,
                                       webkit (default: "chromium")
--color-scheme &lt;scheme&gt;                emulate preferred color scheme, "light" or "dark"
--device &lt;deviceName&gt;                  emulate device, for example"iPhone 11"
--geolocation &lt;coordinates&gt;            specify geolocation coordinates, for example
                                       "37.819722,-122.478611"
--lang &lt;language&gt;                      specify language / locale, for example "en-GB"
--proxy-server &lt;proxy&gt;               specify proxy server, for example "http://myproxy:3128" or
                                       "socks5://myproxy:8080"
--timezone &lt;time zone&gt;               time zone to emulate, for example "Europe/Rome"
--timeout &lt;timeout&gt;                  timeout for Playwright actions in milliseconds (default:
                                       "10000")
--user-agent &lt;ua string&gt;               specify user agent string
--viewport-size &lt;size&gt;               specify browser viewport size in pixels, for example "1280,
                                       720"
-h, --help                           display help for command

Commands:
open                            open page in browser specified via -b, --browser
cr                                open page in Chromium
ff                                open page in Firefox
wk                                open page in WebKit
codegen                 open page and generate code for user actions
screenshot &lt;url&gt; &lt;filename&gt;capture a page screenshot
pdf &lt;url&gt; &lt;filename&gt;         save page as pdf
install                              Ensure browsers necessary for this version of Playwright
                                       are installed
help                          display help for command
</code></pre>
<p>从命令行帮助信息中可以看出,<code>Playwright</code>支持的功能相当丰富!</p>
<h2 id="3-实操演示">3. 实操演示</h2>
<p>开篇就提到,使用Playwright无需写一行代码,我们只需手动操作浏览器,它会录制我们的操作,然后自动生成代码脚本。</p>
<p><strong>3.1 录制脚本</strong></p>
<p>我们先查看录制脚本的命令说明</p>
<pre><code>➜~ python3 -m playwright codegen --help
Usage: index codegen

open page and generate code for user actions

Options:
-o, --output &lt;file name&gt;saves the generated script to a file
--target &lt;language&gt;       language to use, one of javascript, python, python-async, csharp (default: "python")
-h, --help                display help for command

Examples:

$ codegen
$ codegen --target=python
$ -b webkit codegen https://example.com
</code></pre>
<p><strong>其中</strong></p>
<ul>
<li>
<p>python -m playwright codegen录制脚本</p>
</li>
<li>
<p>--help帮助文档</p>
</li>
<li>
<p>-o生成自动化脚本的目录</p>
</li>
<li>
<p>--target 脚本语言,包含 JS 和 Python,分别对应值为:python 和 javascript</p>
</li>
<li>
<p>-b指定浏览器驱动</p>
</li>
</ul>
<p>比如,我要在baidu.com搜索,用chromium驱动,将结果保存为mikezhou.py的python文件。</p>
<pre><code class="language-python"># 我们通过下面命令打开 Chrome 浏览器开始录制脚本
# 指定生成语言为:Python(默认Python,可选)
# 保存的文件名:mikezhou.py(可选)
# 浏览器驱动:webkit(默认webkit,可选)
# 最后跟着要打开的目标网站(默认仅仅是打开浏览器,可选)
python3 -m playwright codegen --target python -o 'mikezhou.py' -b chromium https://www.baidu.com
</code></pre>
<p>命令行输入后会自动打开浏览器,然后可以看见在浏览器上的一举一动都会被自动翻译成代码,如下所示:</p>
<p><img src="https://tva1.sinaimg.cn/large/0081Kckwgy1gloni65ydtj31go0qytic.jpg" alt="" loading="lazy"></p>
<p><img src="https://tva1.sinaimg.cn/large/0081Kckwgy1glonk1oli8j31fv0qn4cr.jpg" alt="" loading="lazy"></p>
<p>最后,自动化脚本会自动生成,保存到文件中<code>mikezhou.py</code>,且上述所有的人工操作,都会被自动转化成代码:</p>
<pre><code class="language-python">from playwright import sync_playwright

def run(playwright):
    browser = playwright.chromium.launch(headless=False)
    context = browser.newContext()

    # Open new page
    page = context.newPage()

    # Go to https://www.baidu.com/
    page.goto("https://www.baidu.com/")

    # Click input
    page.click("input")

    # Fill input
    page.fill("input", "禾目大")

    # Press CapsLock
    page.press("input", "CapsLock")

    # Fill input
    page.fill("input", "自动化测试实战宝典 ")

    # Press Enter
    page.press("input", "Enter")
    # assert page.url() == "https://www.baidu.com/s?ie=utf-8&amp;f=8&amp;rsv_bp=1&amp;rsv_idx=1&amp;tn=baidu&amp;wd=%E8%87%AA%E5%8A%A8%E5%8C%96%E6%B5%8B%E8%AF%95%E5%AE%9E%E6%88%98%E5%AE%9D%E5%85%B8%20&amp;fenlei=256&amp;rsv_pq=af40e9aa00012d5a&amp;rsv_t=c659gpz2%2Fjri1SAoIXdT9gP%2BmrqufXzRtMSSAL0n0fv7GSoLF5vaiNVPA3U&amp;rqlang=cn&amp;rsv_enter=1&amp;rsv_dl=tb&amp;rsv_sug3=38&amp;rsv_sug1=22&amp;rsv_sug7=100&amp;rsv_sug2=0&amp;rsv_btype=i&amp;inputT=8034&amp;rsv_sug4=9153"

    # Close page
    page.close()

    # ---------------------
    context.close()
    browser.close()

with sync_playwright() as playwright:
    run(playwright)
</code></pre>
<p><strong>3.2 支持同步</strong></p>
<p>同步的关键字为:<code>sync_playwright</code></p>
<p>比如,我们依次使用三个浏览器内核打开浏览器,然后百度一下,接着对在搜索界面截图,最后关闭浏览器</p>
<pre><code class="language-python">from time import sleep
from playwright import sync_playwright

# 注意:默认是无头模式
with sync_playwright() as p:
    # 分别对应三个浏览器驱动
    for browser_type in :

      # 指定为有头模式,方便查看
      browser = browser_type.launch(headless=False)
      page = browser.newPage()
      page.goto('http://baidu.com')

      # 执行一次搜索操作
      page.fill("input", "自动化测试实战宝典")
      with page.expect_navigation():
            page.press("input", "Enter")

      # 等待页面加载完全
      page.waitForSelector("text=搜索工具")
      
      # 截图
      page.screenshot(path=f'test-{browser_type.name}.png')

      # 休眠3s
      sleep(3)

      # 关闭浏览器
      browser.close()
</code></pre>
<p>需要指出的是,<code>playwright-python</code> 内置的 API 基本上囊括常见的自动化操作</p>
<p><strong>3.3 支持异步</strong></p>
<p>异步步的关键字为:<code>async_playwright</code>,异步操作可结合asyncio同时进行三个浏览器操作。</p>
<pre><code class="language-python">import asyncio
from playwright import async_playwright

# 异步执行
async def main():
    async with async_playwright() as p:
      for browser_type in :
            # 指定为有头模式,方便查看
            browser = await browser_type.launch(headless=False)
            page = await browser.newPage()

            await page.goto('http://baidu.com')

            # 执行一次搜索操作
            await page.fill("input", "自动化测试实战宝典")
            await page.press("input", "Enter")

            # 等待页面加载完全
            await page.waitForSelector("text=搜索工具")

            # 截图
            await page.screenshot(path=f'test-{browser_type.name}.png')
            await browser.close()

asyncio.get_event_loop().run_until_complete(main())
</code></pre>
<p><strong>3.4 支持移动端</strong></p>
<p>更厉害的是,playwright还可支持移动端的浏览器模拟。下面是官方文档提供的一段代码,模拟在给定地理位置上手机iphone 11 pro上的Safari浏览器,首先导航到maps.google.com,然后执行定位并截图。</p>
<pre><code class="language-python">from playwright import sync_playwright

with sync_playwright() as p:
    iphone_11 = p.devices['iPhone 11 Pro']
    browser = p.webkit.launch(headless=False)
    context = browser.newContext(
      **iphone_11,
      locale='en-US',
      geolocation={ 'longitude': 12.492507, 'latitude': 41.889938 },
      permissions=['geolocation']
    )
    page = context.newPage()
    page.goto('https://maps.google.com')
    page.click('text="Your location"')
    page.screenshot(path='colosseum-iphone.png')
    browser.close()
</code></pre>
<p><strong>3. 5 支持Pytest框架</strong></p>
<p>另外,还可以配合pytest插件一起使用,给出一段官网示例:</p>
<pre><code class="language-python">def test_playwright_is_visible_on_google(page):
    page.goto("https://www.google.com")
    page.type("input", "Playwright GitHub")
    page.click("input")
    page.waitForSelector("text=microsoft/Playwright")
</code></pre>
<p>当然,除了上面列举出来的特性,还有更多有意思的用法,感兴趣的读者可以自行探索一下。</p>
<h4 id="4-最后">4. 最后</h4>
<p>playwright相比已有的自动化测试框架来说,具有有很多优势,比如:</p>
<ul>
<li>跨浏览器,支持Chromium、Firefox、WebKit</li>
<li>跨操作系统,支持Linux、Mac、Windows</li>
<li>可提供录制生成代码功能,解放双手</li>
<li>可用于移动端</li>
</ul>
<p>目前存在的缺点就是生态和文档还不是非常完备,比如没有API中文文档、没有较好的教程和示例供学习。不过相信,随着知道的人越来越多,未来会越来越好。</p>
<p>最后,再说一个小秘密,Playwright 是一个跨语言的自动化框架,除了支持 Python,也支持Java、JS 等,更加详细的功能可以通过官方项目去解锁!</p>
<p>如果你觉得文章还不错,请大家 <strong>点赞、分享、留言</strong> 下,因为这将是我持续输出更多优质文章的最强动力!</p>


</div>
<div id="MySignature" role="contentinfo">
    技术改变世界!
         --狂诗绝剑<br><br>
来源:https://www.cnblogs.com/jinjiangongzuoshi/p/14154605.html
頁: [1]
查看完整版本: 推荐一款最强Python自动化神器!不用写一行代码!