当前位置: 首页 > wzjs >正文

建设工程个人信息采集哪个网站客户关系管理的含义

建设工程个人信息采集哪个网站,客户关系管理的含义,重庆通信管理局网站,陕西省工程造价信息网官网playwright 安装优点基础示例同步代码异步代码启动不同浏览器启用本地浏览器(使用浏览器cookie信息)playwright页面接管设置环境变量和cmd启动浏览器 窗口最大化录制脚本录制脚本保存身份验证状态代码中保存身份状态信息代码中读取身份状态信息 playwrig…

playwright

    • 安装
    • 优点
    • 基础示例
      • 同步代码
      • 异步代码
      • 启动不同浏览器
      • 启用本地浏览器(使用浏览器cookie信息)
      • playwright页面接管
        • 设置环境变量和cmd启动浏览器
      • 窗口最大化
      • 录制脚本
        • 录制脚本保存身份验证状态
        • 代码中保存身份状态信息
        • 代码中读取身份状态信息
    • playwright发送api接口请求

安装

pip install pytest-playwright
playwright install

优点

  • 支持异步操作(assync_api)
  • 同步操作调用:sync_api

基础示例

同步代码

from playwright.sync_api import sync_playwrightwith sync_playwright() as playwright:browser = playwright.chromium.launch()page = browser.new_page()page.goto('https://www.baidu.com')print(page.title())browser.close()

异步代码

  • 异步代码需要两个关键字:asyncawait
  • 异步方法启动需要使用导入asyncio包,运行asyncio.run()执行main()方法。
import asyncio
from playwright.async_api import async_playwrightasync def main():async with async_playwright() as p:# headless = False : 是否启动无头模式,无头模式是不弹出浏览器,后台运行browser = await p.chromium.launch(headless=False)page = await browser.new_page()await page.goto('https://www.baidu.com')print(await page.title())await browser.close()asyncio.run(main())

启动不同浏览器

  • 浏览器默认情况下是以无痕模式启动
  • channel:“chrome”, “chrome-beta”, “chrome-dev”, “chrome-canary”, “msedge”, “msedge-beta”, “msedge-dev”, or “msedge-canary”
  • chromium:谷歌开源内核
def run(playwright: Playwright) -> None:# "chrome", "chrome-beta", "chrome-dev", "chrome-canary", "msedge", "msedge-beta", "msedge-dev", or "msedge-canary"browser = playwright.chromium.launch(headless=False, channel='msedge')context = browser.new_context()page = context.new_page()page.goto("https://www.baidu.com/")# ---------------------context.close()browser.close()with sync_playwright() as playwright:run(playwright)
  • 火狐

from playwright.sync_api import sync_playwright
with sync_playwright() as playwright:# 火狐browser_f = playwright.firefox.launch()page = browser_f.new_page()page.goto('https://www.bing.com')print(page.title())browser_f.close()

启用本地浏览器(使用浏览器cookie信息)

from playwright.sync_api import Playwright, sync_playwright
import getpassuser_data_dir = fr'C:\Users\{getpass.getuser()}\AppData\Local\Google\Chrome\User Data'def run(playwright: Playwright) -> None:context = playwright.chromium.launch_persistent_context(# 本地浏览器的数据目录user_data_dir=user_data_dir,# 指定Googlechannel='chrome',# 无头模式headless=False)page = context.new_page()page.goto("https://www.baidu.com/")page.pause()# ---------------------context.close()with sync_playwright() as playwright:run(playwright)

playwright页面接管

  • 针对场景:退出浏览器就需要重新登录,并且存在复杂的验证信息
设置环境变量和cmd启动浏览器
  1. 将起始位置添加到环境变量中,并且保证cmd命令窗口输出chrome直接启动浏览器。
    在这里插入图片描述
  2. 在cmd窗口中,输入启动命令和配置参数信息。
  • 指定端口:--remote-debugging-port=8888
  • 指定浏览器数据目录:--user-data-dir="D:\playwright_chrome_user_data"
chrome --remote-debugging-port=8888 --user-data-dir="D:\playwright_chrome_user_data"

在这里插入图片描述
3. 使用cdp链接chrome浏览器。

from playwright.sync_api import Playwright, sync_playwrightdef run(playwright: Playwright) -> None:browser = playwright.chromium.connect_over_cdp('http://localhost:8888')page = browser.contexts[0].pages[0]page.goto("https://www.baidu.com/")page.pause()# ---------------------page.close()with sync_playwright() as playwright:run(playwright)

窗口最大化

  • --start-maximized:该参数来源是chromium浏览器命令行参数列表,https://peter.sh/experiments/chromium-command-line-switches/。
  • no_viewport=True
import re
from playwright.sync_api import Playwright, sync_playwright, expectdef run(playwright: Playwright) -> None:browser = playwright.chromium.launch(headless=False, args=['--start-maximized'])context = browser.new_context(no_viewport=True)page = context.new_page()page.goto("https://www.baidu.com/")# ---------------------context.close()browser.close()with sync_playwright() as playwright:run(playwright)

录制脚本

  • 命令:
playwright codegen
  • 示例:playwright codegen https://www.baidu.com
from playwright.sync_api import Playwright, sync_playwright, expectdef run(playwright: Playwright) -> None:browser = playwright.chromium.launch(headless=False)context = browser.new_context()page = context.new_page()page.goto("http://xx.xx.xx.xx:8080/login")page.get_by_role("textbox", name="用户名").click()page.get_by_role("textbox", name="用户名").fill("admin")page.get_by_role("textbox", name="密码").click()page.get_by_role("textbox", name="密码").fill("admin123")page.get_by_role("button", name="登录").click()# ---------------------context.close()browser.close()with sync_playwright() as playwright:run(playwright)
录制脚本保存身份验证状态
  • --save-storage:会保存cookie和localStorage。
  • --load-storage:加载保存在本地的cookie信息。
  • openplaywright open启动浏览器与codegen效果相似。

保存cookie信息

playwright codegen --save-storage=auto.json

加载cookie信息

playwright open http://xx.xx.xx.xx:8080/system/user --load-storage=auto.json
代码中保存身份状态信息
  • 若导出的文件cookie信息为空,需要确认网站cookie的失效机制,是否关闭浏览器或者关闭页面即失效
from playwright.sync_api import Playwright, sync_playwright, expectdef run(playwright: Playwright) -> None:browser = playwright.chromium.launch(headless=False)context = browser.new_context()page = context.new_page()page.goto("http://xx.xx.xx.xx:8080/login")page.get_by_role("textbox", name="用户名").click()page.get_by_role("textbox", name="用户名").fill("admin")page.get_by_role("textbox", name="密码").click()page.get_by_role("textbox", name="密码").fill("admin123")page.get_by_role("button", name="登录").click()# 添加等待事件,保证登录信息的获取page.wait_for_url(url='http://xx.xx.xx.xx:8080/index')# 保存storage state 到指定的文件storage = context.storage_state(path="../auth/ry_auto.json")# ---------------------context.close()browser.close()with sync_playwright() as playwright:run(playwright)
代码中读取身份状态信息
from playwright.sync_api import Playwright, sync_playwright, expectdef run(playwright: Playwright) -> None:browser = playwright.chromium.launch(headless=False)context = browser.new_context(storage_state="state.json")

playwright发送api接口请求

@pytest.fixture(scope="session")
def api_request_context(playwright: Playwright,
) -> Generator[APIRequestContext, None, None]:headers = {# We set this header per GitHub guidelines."Accept": "application/vnd.github.v3+json",# Add authorization token to all requests.# Assuming personal access token available in the environment."Authorization": f"token {GITHUB_API_TOKEN}",}request_context = playwright.request.new_context(base_url="https://api.github.com", extra_http_headers=headers)yield request_contextrequest_context.dispose()

文章转载自:

http://2AiLIHjE.xqtqm.cn
http://As2NRIpK.xqtqm.cn
http://0nxSoDoz.xqtqm.cn
http://XCAO6gLt.xqtqm.cn
http://wfrbCXo6.xqtqm.cn
http://2CXxQMcU.xqtqm.cn
http://WGoKo1xA.xqtqm.cn
http://3TEMbbZj.xqtqm.cn
http://c2TPkUGA.xqtqm.cn
http://q1WpnYy4.xqtqm.cn
http://G0ZeLIfi.xqtqm.cn
http://bCShCSrE.xqtqm.cn
http://vZGKJbuh.xqtqm.cn
http://fpzzfD6x.xqtqm.cn
http://6gTnHYS9.xqtqm.cn
http://hD9hAS4s.xqtqm.cn
http://bFm3aOWH.xqtqm.cn
http://rFPg9yWo.xqtqm.cn
http://xxxugt4T.xqtqm.cn
http://UCG6saXn.xqtqm.cn
http://2M6E4Md8.xqtqm.cn
http://vZeTXBmX.xqtqm.cn
http://FRRjNvzH.xqtqm.cn
http://FzEoDcf1.xqtqm.cn
http://rpCW5TO9.xqtqm.cn
http://KgclBlGm.xqtqm.cn
http://lrE5Mnkv.xqtqm.cn
http://xcjoc5CG.xqtqm.cn
http://ZFnhw08h.xqtqm.cn
http://yQzofTLq.xqtqm.cn
http://www.dtcms.com/wzjs/707674.html

相关文章:

  • 用wix做网站需要备案吗收费网站开发
  • 电商网站储值消费系统网站前置审批类型
  • 烟台网站建设哪家便宜广州百度seo公司
  • 网站维护的要求包括哪些wordpress主题仿虎嗅
  • 长沙3合1网站建设各大网站网址目录
  • 巴彦淖尔网站制作中国建筑有几个工程局
  • 邓州网站优化智能建造师报名入口官网
  • 网站建设考核标准局域网的常用技术是什么
  • 聊城做网站的公司案例创建一个app需要什么
  • 安云自助建站系统源码wordpress 换主题
  • 上海免费网站建设模板建设网站修改图片
  • 网站维护是什么职位网站建设详细需求文档
  • linux做网站网络课堂佛山网站建设 天博
  • 设计交流网站保洁公司做网站有什么作用
  • 江西华邦网站建设网站快速注册
  • 临沂网站设计建设河北省建设厅注册中心网站
  • 大连做网站优化价格企业管理系统数据库设计
  • 圣辉友联网站建设一家只做外卖的网站
  • 徐州企业网站推广网站建设专家评审意见
  • html5 微信网站wordpress 搬迁
  • 可以免费建网站的网站备案 条例
  • 简洁网站模板素材网站域名代理备案
  • 长春做网站哪家便宜古镇做灯饰网站的公司
  • 沈阳网站建设哪里的公司比较好网站创建桌面快捷方式
  • 网站建设方案范例云服务器如何安装网站
  • 网站开发主管网站建设案例教程视频教程
  • wap网站制作需要多少钱佛山专业建站公司
  • 网站风格南宁个人网站建设
  • 兰州程序开发网站建设西安seo关键词排名优化
  • 深圳公司建站推广廊坊做网站优化