#coding=utf-8
from selenium import webdriver
import time
driver = webdriver.Firefox()
driver.get("https://www.baidu.com/")
#给搜索输入框标红javascript脚本
js="var q=document.getElementById(\"kw\");q.style.border=\"2px solid red\";"
#调用给搜索输入框标红js脚本
driver.execute_script(js)
time.sleep(3)
#单独执行js脚本
driver.execute_script('alert("输入框标红了!")')
time.sleep(3)
#接受提示信息
driver.switch_to_alert().accept()
time.sleep(3)
#js隐藏元素,将获取的图片元素隐藏
img1 = driver.find_element_by_xpath("//*[@id='lg']/img")
driver.execute_script('$(arguments[0]).fadeOut()',img1)
time.sleep(3)
driver.find_element_by_xpath("//*[@id='kw']").send_keys("selenium")
driver.find_element_by_xpath("//*[@id='su']").click()
time.sleep(3)
driver.quit()

原文地址:https://blog.csdn.net/u013372487/article/details/46502853

js中设置元素class的三种方法小结

<!DOCTYPE HTML>
<HTML>
<HEAD>
<meta charset="utf-8" />
<title>el.className = 'abc'</title>
<style type="text/css">
.abc {
background: red;
}
</style>
</HEAD>
<BODY>
<div id="d1">test div</div>
<script>
var div = document.getElementById('d1');
div.className = 'abc';
</script>
</BODY>
</HTML>
js="var div = document.getElementById(\"kw\");div.className = \"abc\";"
driver[0].execute_script(js)
先定位到ID 然后修改这个ID的class属性
//JavaScript属性选择器 选中后用来更改属性值
var a=document.querySelector("div[data-hover-cls=inputs-hover]");
//更改属性值class为“”
a.setAttribute("class","")
//注意此方法只适用于ID CLASS TAG之外的子属性的选择
js = "var a=document.querySelector(\"div[data-hover-cls=inputs-hover]\");a.setAttribute(\"class\",\"inputs J_LaterHover inputs-hover\")"
self.driver.execute_script(js) jiage_mini = "var a=document.querySelector(\"input[aria-label=价格最小值]\");a.setAttribute(\"value\",\"50\")"
self.driver.execute_script(jiage_mini)
jiage_max = "var a=document.querySelector(\"input[aria-label=价格最大值]\");a.setAttribute(\"value\",\"50\")"
self.driver.execute_script(jiage_max) submit="var a=document.querySelector(\"button[type=button]\"),a.click()"
self.driver.execute_script(submit)

小例子

TB翻页

var button=document.querySelector("a[trace=srp_select_pagedown]")

XP查看更多

var button=document.querySelector("div[class=item-collection-detail__products-more]")
button.click()


虾皮

单次点击【查看更多】
var button=document.querySelector("div[class=item-collection-detail__products-more]")
button.click()

循环点击【查看更多】
for (var i=1; i<10; i++)
{

//延时1秒执行 https://www.oschina.net/question/141209_21625?sort=time
var beginTime=new Date().getTime();
while(new Date().getTime() < beginTime + 2000) {

}
//要执行的代码
var button=document.querySelector("div[class=item-collection-detail__products-more]");
button.click();
}

循环点击新增

//class选择器【分类添加商品】
var a=document.getElementsByClassName("item-collection-detail__products-item__action")
for (var i=1; i<10; i++)
{ a[i].click();
//延时器
var beginTime=new Date().getTime();
while(new Date().getTime() < beginTime + 200) {
}
}
//i=商品数量 beginTime=间隔时间

精华 selenium_webdriver(python)调用js脚本的更多相关文章

  1. 最全总结!聊聊 Python 调用 JS 的几种方式

    1. 前言 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很多已经做案例的人,却不知道如何去学习更加高深的知识.那么针对这三类人,我给大 ...

  2. Python 调用 Shell脚本的方法

    Python 调用 Shell脚本的方法 1.os模块的popen方法 通过 os.popen() 返回的是 file read 的对象,对其进行读取 read() 的操作可以看到执行的输出. > ...

  3. iOS:在OC中调用JS脚本

    示例一:在webView中调用js脚本进行搜索 1.首先导入JavaScriptCore.framework这个框架 2.创建webView.设置代理.请求手机端百度 #import "Vi ...

  4. Python 调用JS文件中的函数

    Python 调用JS文件中的函数 1.安装PyExecJS第三方库 2.导入库:import execjs 3.调用JS文件中的方法 Passwd = execjs.compile(open(r&q ...

  5. python 调用js代码

    Python2   安装pyv8 pip install-egit://github.com/brokenseal/PyV8-OS-X#egg=pyv8 from pyv8 import PyV8 c ...

  6. java中调用js脚本

    JDK1.6加入了对Script(JSR223)的支持.这是一个脚本框架,提供了让脚本语言来访问Java内部的方法.你可以在运行的时候找到脚本引擎,然后调用这个引擎去执行脚本.这个脚本API允许你为脚 ...

  7. python调用shell脚本时需要切换目录

    最近遇到了一个问题,就是python代码调用shell脚本时,发现输入输出的文件,总是和自己预想的有偏差,但是单独在linux下执行命令的时候,却没有错误.后来发现是相对路径的问题,因为执行pytho ...

  8. java调用js脚本

    有些情况下,需要java去调用js,groovy等脚本语言,传入参数获取脚本运行的结果. js脚本例子: function add(a,b){ return a + b + number; } jav ...

  9. python调用其他脚本

    1.用python调用python脚本 #!/usr/local/bin/python3. import time import os count = str = ('python b.py') re ...

随机推荐

  1. switch反汇编(C语言)

    在分支较多的时候,switch的效率比if高,在反汇编中我们即可看到效率高的原因 0x01分支结构不超过3个 #include <stdio.h> void main() { int x ...

  2. c# 之 Microsoft.Practices.EnterpriseLibrary连接Oracle

    首先下载Microsoft Enterprise Library 5.0:http://www.microsoft.com/en-us/download/details.aspx?id=15104,这 ...

  3. docker 安装redis

    https://blog.csdn.net/chenjianandiyi/article/details/78962709 运行镜像redis:  docker run --name redis1 - ...

  4. Cisco 2960交换机配置

    一. 基本操作 Switch(config)#hostname test01(交换机名称) //全局模式下修改交换机名称 Switch(config)#enable secret 123456 //全 ...

  5. Unity3D学习笔记(二十六):MVC框架下的背包系统(1)

    MVC背包 需求: 1.背包格子的装备是可以拖动的 2.装备栏的装备也是可以拖动的 3.当背包格子的装备拖动到装备栏时,如果是装备类型和装备栏类型是一致的能装上 4.背包的装备是按照顺序放在格子中的, ...

  6. Jmeter工具

    开源,纯java,用于HTTP协议性能测试,接口协议测试工具,自动化测试工具 功能测试角度: 1.支持多种不同类型的协议.接口协议有多种 2.可以全面支持HTTP协议(后台交互) 3.其他非直接支持的 ...

  7. 1.1.1 vue-cli脚手架工具

    参考文档: windows下npm安装vue(以下教程大部分都是参考这篇博客的,按照着这篇博客自己实现了一遍) npm安装vue-cli脚手架 一.前言 npm:nodejs下的包管理器,安装好nod ...

  8. java常用技术名词解析

    1.1 token Token是服务端生成的一串字符串,以作客户端进行请求的一个令牌,当第一次登录后,服务器生成一个Token便 将此Token返回给客户端,以后客户端只需带上这个Token前来请求数 ...

  9. 有了art-template,如有神助

    <div class="form-group col-lg-12"> <label class="control-label col-lg-3 text ...

  10. 前端阶段_html部分

    HTML 1.html5的第一行一定是<!DOCTYPE html>,h4太长,而且一般ide中会自动加载,了解即可. 2.h5的整个页面被<html></html> ...