亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在 selenium 中使用多行腳本來執行腳本

如何在 selenium 中使用多行腳本來執行腳本

繁星coding 2021-12-17 16:08:39
我正在使用 selenium 的 driver.execute_script 函數在頁面上部署一些 JavaScript。我準備了我的 JavaScript 但如果我將代碼放到另一行中,如下所示:script = 'line one code' +         'line two code'driver.execute_script(script)它給了我一個錯誤。我也試過這樣做:script = [    'line one code',    'line two code']script = ';'.join(script)但這給了我同樣的錯誤。
查看完整描述

2 回答

?
慕哥6287543

TA貢獻1831條經驗 獲得超10個贊

要構建多行腳本,您可以借助三重引號ie """ ... """。


這是通過execute_script()使用Selenium調用的多行腳本示例:


def wheel_element(element, deltaY = 120, offsetX = 0, offsetY = 0):

  error = element._parent.execute_script("""

    var element = arguments[0];

    var deltaY = arguments[1];

    var box = element.getBoundingClientRect();

    var clientX = box.left + (arguments[2] || box.width / 2);

    var clientY = box.top + (arguments[3] || box.height / 2);

    var target = element.ownerDocument.elementFromPoint(clientX, clientY);


    for (var e = target; e; e = e.parentElement) {

      if (e === element) {

        target.dispatchEvent(new MouseEvent('mouseover', {view: window, bubbles: true, cancelable: true, clientX: clientX, clientY: clientY}));

        target.dispatchEvent(new MouseEvent('mousemove', {view: window, bubbles: true, cancelable: true, clientX: clientX, clientY: clientY}));

        target.dispatchEvent(new WheelEvent('wheel',     {view: window, bubbles: true, cancelable: true, clientX: clientX, clientY: clientY, deltaY: deltaY}));

        return;

      }

    }    

    return "Element is not interactable";

    """, element, deltaY, offsetX, offsetY)

您可以將方法調用為:


wheel_element(elm, -120)


查看完整回答
反對 回復 2021-12-17
?
慕斯709654

TA貢獻1840條經驗 獲得超5個贊

\在+符號后添加


script = 'line one code ' + \

         'line two code'

或者使用圓括號


script = ('line one code '

          'line two code')


查看完整回答
反對 回復 2021-12-17
  • 2 回答
  • 0 關注
  • 261 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號