1)alert框的处理
前提:我们是不可以通过控制台直接定位元素的方式去选中这个alert框的,例如说xpath直接进行定位元素
1)先获得弹框的操作句柄:alert=driver.switch_to.alert
2)再次调用accept方法进行关闭弹窗:alert.accept()
from selenium import webdriver import time driver=webdriver.Edge("C://Users//18947//AppData//Local//Programs//Python//Python310//msedgedriver.exe") url="D:\selenium2html\\alert.html" # 1.先打开浏览器的界面 driver.get(url) # 2.定位元素,先进行打开弹窗 driver.find_element_by_link_text("hover to see tooltip").click() time.sleep(4) # 3.进行选中弹出框,我们在进行选中操作弹出框的句柄 alert=driver.switch_to.alert # 4.强制使用accept方法进行关闭alert框 alert.accept() time.sleep(3) driver.quit()选中a标签也就是超链接,这里面我们既可以通过tagname的方式,也可以通过id的方式来进行获取:
我们点击弹出框,在进行关闭:
from selenium import webdriver; import time; import os; driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe"); filepath="file:///"+os.path.abspath("D:\selenium2html\\alert.html"); #通过浏览器进行打开文件 driver.get(filepath); #先进行选中这个触发alert的a标签 a=driver.find_element_by_tag_name("a"); a.click(); time.sleep(3); #我们在进行选中操作弹出框的句柄 alert=driver.switch_to.alert alert.accept(); time.sleep(3); driver.quit();
2)点击链接之后我们需要在这个弹框里面输入一些东西,然后这些东西最终就会展示在界面上面:
前提:我们是不可以通过控制台直接定位元素的方式去选中这个alert框的,例如说xpath直接进行定位元素
操作步骤:
1)先获得alert框的输入句柄:alert=driver.switch_to.alert
2)向alert框中输入信息:alert.send_keys()
3)调用accept方法关闭输入框:alert.accept()
from selenium import webdriver import time # 1.先获取浏览器的驱动 driver=webdriver.Edge("C://Users//18947//AppData//Local//Programs//Python//Python310//msedgedriver.exe") # 2.提前设置好要展示的url url="D:\selenium2html\\send.html" # 3.打开浏览器在搜索栏里面输入相应的url driver.get(url) # 4.先进行点击那个固定的超链接然后再继续进行点击 driver.find_element_by_xpath("/html/body/input").click() time.sleep(4) # 5.获得弹出框的操作句柄 alert=driver.switch_to.alert time.sleep(2) alert.send_keys("中国好青年") time.sleep(2) alert.accept() time.sleep(2) # 6.关闭浏览器 driver.quit()
3)再次进行点击上面的click me就会又显示出一段文字,最后再进行关闭输入框即可
4)目标就是点击divclass=myModal里面的嵌套的div class=modal-bod里面的a标签
5)关闭弹出框
![]()
定位方式1:
from selenium import webdriver import time import os # 1.先获取谷歌浏览器的驱动 driver=webdriver.Chrome("C://Users//18947//AppData//Local//Programs//Python//Python310//chromedriver.exe") # 2.让浏览器打开本地文件 url="file:///"+os.path.abspath("C:\selenium2html\\modal.html") driver.get(url) time.sleep(2) # 3.先定位到Click标签再进行点击 driver.find_element_by_xpath("//*[@id='show_modal']").click() time.sleep(3) # 4.进行点击弹出框的a标签 driver.find_element_by_xpath("//*[@id='click']").click() time.sleep(2) # 5.最后选择输入弹出框的close按钮 driver.find_element_by_xpath("//*[@id='myModal']/div[3]/button[1]").click() # 6.关闭浏览器 driver.close()
定位方式2:
from selenium import webdriver; import time; import os; driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe"); filepath="file:///"+os.path.abspath("D:\selenium2html\\modal.html"); driver.get(filepath); #先进行点击页面上面的初始按钮 driver.find_element_by_id("show_modal").click(); time.sleep(3); #先选中弹框点击按钮所在的div,再来定位到这个div里面所要包含的a标签 fatherdiv=driver.find_element_by_class_name("modal-body"); fatherdiv.find_element_by_link_text("click me").click(); #在进行点击close关闭按钮,先进行关联这个close关闭按钮所在的父亲标签,再去定位这个点击按钮 time.sleep(3); parentdiv=driver.find_element_by_class_name("modal-footer"); parentdiv.find_element_by_class_name("btn").click(); time.sleep(5);
定位方式3:
通过获取到数组来获取到点击按钮
from selenium import webdriver; import time; import os; driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe"); filepath="file:///"+os.path.abspath("D:\selenium2html\\modal.html"); driver.get(filepath); #先进行点击页面上面的初始按钮 driver.find_element_by_id("show_modal").click(); time.sleep(3); #先选中弹框点击按钮所在的div fatherdiv=driver.find_element_by_class_name("modal-body"); fatherdiv.find_element_by_link_text("click me").click(); #在进行点击close关闭按钮 time.sleep(3); parentdiv=driver.find_element_by_class_name("modal-footer"); butons=driver.find_elements_by_tag_name("button"); butons[0].click(); time.sleep(5);1)先获取到元素所在的div
2)再(1)的基础上,在来定位对应的元素
适用于页面比较复杂的情况,可以大大降低元素因为重复属性而无法唯一定位的问题
上传文件:
1)send_keys可以上传文件,里面方法的参数就是文件所在的绝对路径
2)先进行选中上传文件的按钮,在zend_keys()里面填写文件的路径
自动化测试脚本:
from selenium import webdriver import time import os # 1.先获取到浏览器的驱动 driver=webdriver.Edge("C://Users//18947//AppData//Local//Programs//Python//Python310//msedgedriver.exe") # 2.打开网址 url="D:\selenium2html\\upload.html" driver.get(url) time.sleep(3) # 3.选择上传文件按钮 driver.find_element_by_xpath("/html/body/div/div/input").send_keys("D:/aaa.jpg") time.sleep(2) driver.close();
1)在WebDriver中处理JavaScript所生成的alert、confirm以及prompt十分简单,只需要使用switch_to.alert定位到alert/confirm/prompt
2)然后使用text/accept/dismiss/send_keys等方法进行操作
弹框类型有:
弹框 类型 特性 alert 警告类,显示警告或其他信息 只有一个确认按钮 confirm 确认类,询问是否继续某种操作等功能 只有两个按钮:确认按钮+取消按钮 prompt 消息类,需要输入一些信息,比如用户密码等 有两个按钮:确认按钮+取消按钮,加一个输入框
弹框方法:
1)text:返回alert/confirm/prompt中的弹框文本信息
2)accept():确认按钮
3)dismiss():取消按钮
4)send_keys():prompt弹框输入字符
执行js脚本触发弹框方法:
alert弹框:driver.execute_script(“window.alert(‘这是一个alert弹框’);”)
confirm弹框:driver.execute_script(“window.confirm(‘这是一个confirm弹框’);”)
prompt弹框:driver.execute_script(“window.prompt(‘这是一个prompt弹框’);”)
from selenium import webdriver import time # 1.先获取到浏览器的驱动 driver=webdriver.Edge("C://Users//18947//AppData//Local//Programs//Python//Python310//msedgedriver.exe") # 2.打开网址 driver.get("http://www.baidu.com") time.sleep(3) # 3.执行js脚本触发confirm弹框 driver.execute_script("window.confirm('这是一个confirm弹框');") time.sleep(3) # 4.点击谭康中的确认按钮或者是取消按钮 confirm=driver.switch_to.alert time.sleep(2) confirm.dismiss() time.sleep(2) # 5.关闭浏览器 driver.close()
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
我有一个在Linux服务器上运行的ruby脚本。它不使用rails或任何东西。它基本上是一个命令行ruby脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("