Selenium超级详细的教程,2024年最新2024年Golang开发者常见面试题

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Golang全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注go)
img

正文

相信搞过Python的人绝大部分都会一点点爬虫技能,但是很多时候爬虫也不是万能的,这个时候就需要我们的自动化测试框架了,于是Selenium就应运而生了,它可以算的上是自动化测试框架中的佼佼者,因为它解决了大多数用来爬取页面的模块的一个永远的痛,那就是Ajax异步加载,今天小编就带大家来好好了解下这个Selenium 。
Selenium 版本仅合适>=4.2.0

一、安装与导入

这里我们需要安装三个东西,一个是Selenium框架,还有一个浏览器,最后就是驱动。这里小编选择了谷歌浏览器,下载地址:谷歌浏览器。然后Selenium框架嘛,大家都会下的啦,pip就搞定了,最后就是要下载个Chrome浏览器的驱动程序,为了让Selenium和浏览器之间产生关联的一个东西,下载地址:chromedriver(注意谷歌浏览器与驱动chromedriver有版本匹配问题!谷歌浏览器会强制更新软件可以考虑拿一个绿色版到项目里面,然后配置一下浏览器的路径就好)。安装好浏览器后,将浏览器驱动放在浏览器同级目录下,这样前期工作就算都预备好了。

注:不要随便乱下浏览器和驱动,每个浏览器和驱动器的版本都必须是一一对应的,不是通用的。

二、与浏览器建立连接

做好前面的准备工作,我们只需要写入几行Python代码即可与浏览器进行交互,如下:

from selenium import webdriver
c=webdriver.Chrome(executable_path=r’./chromedriver.exe’) #获取chrome浏览器的驱动,并启动Chrome浏览器
c.get(‘https://www.baidu.com’)#打开百度

三、查找元素

对于操作浏览器中的页面的自动化测试框架来说,肯定少不了 去发现网页中的元素,你只有发现那些元素实时存在了才能做出下一步的操作。Selenium中提供了众多的方法供我们去找到网页中的元素,这给我们带来了很大的便利,那么都有哪些方法了,我们可以通过Python快速获取到这些方法:
在这里插入图片描述

可以看到只要是前面带有Find字样的方法都是。下面我们来简要说说这些方法的作用以及如何使用,如下:

find_element #通过指定方法查找指定的一个元素(需指定两个参数)
find_element_by_class_name #通过Class name查找指定的一个元素
find_element_by_css_selector #通过CSS选择器查找指定的一个元素
find_element_by_id #通过ID查找指定的一个元素
find_element_by_link_text #通过链接文本获取指定的一个超链接(精确匹配)
find_element_by_name #通过Name查找指定的一个元素
find_element_by_partial_link_text #通过链接文本获取指定的一个超链接(模糊匹配)
find_element_by_tag_name #通过标签名查找指定的一个元素
find_element_by_xpath #通过Xpath语法来指定的一个元素
find_elements #通过指定方法查找所有元素(需指定两个参数)
find_elements_by_class_name #通过Class name查找所有元素
find_elements_by_css_selector #通过CSS选择器查找所有元素
find_elements_by_id #通过ID查找所有元素
find_elements_by_link_text #通过链接文本获取所有超链接(精确匹配)
find_elements_by_name #通过Name查找所有元素
find_elements_by_partial_link_text #通过链接文本获取所有超链接(模糊匹配)
find_elements_by_tag_name #通过标签名查找所有元素
find_elements_by_xpath #通过Xpath语法来查找所有元素

下面我们就上面提到的方法做部分解读,这里我们选择打开百度首页并且定位输入框,如下:
在这里插入图片描述

可以看到输入框的ID为KW,Name为WD,这里我们选择ID,选择ID有三种方法,如下:

from selenium import webdriver
from selenium.webdriver.common.by import By
c=webdriver.Chrome(executable_path=r’./chromedriver.exe’)
c.get(‘https://www.baidu.com’)
kw1=c.find_element(By.ID,‘kw’)
kw2=c.find_element_by_id(‘kw’)
kw3=c.find_elements_by_id(‘kw’)[0]
print(kw1)
print(kw2)
print(kw3)

web自动化测试框架-----Selenium大揭秘

可以看到我们成功使用三种方法获取到了这个元素,其它方法差不多,都是一通百通,喜欢哪种方法就使用哪种方法。

四、浏览器操作

1.获取本页面URL

c.current_url

2.获取日志

c.log_types #获取当前日志类型
c.get_log(‘browser’)#浏览器操作日志
c.get_log(‘driver’) #设备日志
c.get_log(‘client’) #客户端日志
c.get_log(‘server’) #服务端日志

##3.窗口操作
c.maximize_window()#最大化
c.fullscreen_window() #全屏
c.minimize_window() #最小化
c.get_window_position() #获取窗口的坐标
c.get_window_rect()#获取窗口的大小和坐标
c.get_window_size()#获取窗口的大小
c.set_window_position(100,200)#设置窗口的坐标
c.set_window_rect(100,200,32,50) #设置窗口的大小和坐标
c.set_window_size(400,600)#设置窗口的大小
c.current_window_handle #返回当前窗口的句柄
c.window_handles #返回当前会话中的所有窗口的句柄

4.设置延时

c.set_script_timeout(5) #设置脚本延时五秒后执行
c.set_page_load_timeout(5)#设置页面读取时间延时五秒

5.关闭

c.close() #关闭当前标签页
c.quit() #关闭浏览器并关闭驱动

6.打印网页源代码

c.page_source

7.屏幕截图操作

c.save_screenshot(‘1.png’)#截图,只支持PNG格式
c.get_screenshot_as_png() #获取当前窗口的截图作为二进制数据
c.get_screenshot_as_base64() #获取当前窗口的截图作为base64编码的字符串

8.前进后退刷新
c.forward() #前进
c.back() #后退
c.refresh()#刷新

9.执行JS代码

在Selenium中也可以自定义JS代码并带到当前页面中去执行,如下:

from selenium import webdriver
from selenium.webdriver.common.by import By
import time
c=webdriver.Chrome(executable_path=r’./chromedriver.exe’)
c.get(‘https://www.baidu.com’)
kw1=c.find_element(By.ID,‘kw’)
c.execute_script(“alert(‘hello’)”)
time.sleep(3)
c.quit()

在这里插入图片描述

这里我使用一个JS中的函数来执行屏幕提示的功能,成功被执行。

10.Cookies操作

c.get_cookie(‘BAIDUID’) #获取指定键的Cookies
c.get_cookies() #获取所有的Cookies
for y in c.get_cookies():
x=y
if x.get(‘expiry’):
x.pop(‘expiry’)
c.add_cookie(x) #添加Cookies
c.delete_cookie(‘BAIDUID’) #删除指定键的Cookies内容
c.delete_all_cookies() #删除所有cookies

11.获取标题内容

c.title

12.获取当前浏览器名

c.name

13.全局超时时间

c.implicitly_wait(5)

web自动化测试框架-----Selenium大揭秘

五、元素操作

对我们找到的元素进行二次操作,不仅可以再次选择子元素还可以进行其它操作。如下:

kw1.clear() #清除元素的值
kw1.click() #点击元素
kw1.id #Selenium所使用的内部ID
kw1.get_property(‘background’) #获取元素的属性的值
kw1.get_attribute(‘id’) #获取元素的属性的值
kw1.location #不滚动获取元素的坐标
kw1.location_once_scrolled_into_view #不滚动且底部对齐并获取元素的坐标
kw1.parent #父元素
kw1.send_keys(‘’) #向元素内输入值
kw1.size #大小
kw1.submit #提交
kw1.screenshot(‘2.png’) #截取元素形状并保存为图片
kw1.tag_name #标签名
kw1.text #内容,如果是表单元素则无法获取
kw1.is_selected() #判断元素是否被选中
kw1.is_enabled() #判断元素是否可编辑
kw1.is_displayed #判断元素是否显示
kw1.value_of_css_property(‘color’) #获取元素属性的值
kw1._upload(‘2.png’) #上传文件

web自动化测试框架-----Selenium大揭秘

六、键盘鼠标操作

1.模拟键盘输入和按键

from selenium.webdriver.common.keys import Keys
c.find_element(By.ID,‘kw’).send_keys(‘python’)#输出Python
c.find_element(By.ID,‘kw’).send_keys(Keys.ENTER)#回车键
c.find_element(By.ID,‘kw’).click()#点击

这里列举出了一个最简单的键盘输入和鼠标点击的例子,不过我们在Selenium中可以使用更为高逼格的操作,那么是什么了?当然是咱们的鼠标键盘监听事件来触发事件啦,而且它里面的方法的确也很多样化,满足小编日常的骚操作不在话下,如下所示:

click(on_element=None) #鼠标左键单击
click_and_hold(on_element=None) #单击鼠标左键,不松开
context_click(on_element=None) #单击鼠标右键
double_click(on_element=None) #双击鼠标左键
drag_and_drop(source,target) #拖拽到某个元素然后松开
drag_and_drop_by_offset(source,xoffset,yoffset) #拖拽到某个坐标然后松开
key_down(value,element=None) #按下键盘上的某个键
key_up(value, element=None) #松开键盘上的某个键
move_by_offset(xoffset, yoffset) #鼠标从当前位置移动到某个坐标
move_to_element(to_element) #鼠标移动到某个元素
move_to_element_with_offset(to_element, xoffset, yoffset) #移动到距某个元素(左上角坐标)多少距离的位置
pause(seconds) #暂停所有输入(指定持续时间以秒为单位)
perform() #执行所有操作
reset_actions() #结束已经存在的操作并重置
release(on_element=None) #在某个元素位置松开鼠标左键
send_keys(*keys_to_send) #发送某个键或者输入文本到当前焦点的元素
send_keys_to_element(element, *keys_to_send) #发送某个键到指定元素

以上就是咱们鼠标和键盘的全部操作了,小编将用一个例子带大家零基础入门。如下:

from selenium import webdriver
from selenium.webdriver.common.by import By
import time
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.action_chains import ActionChains
c=webdriver.Chrome(executable_path=r’./chromedriver.exe’)
c.get(‘https://www.baidu.com’)
a=ActionChains©
kw1=c.find_element(By.ID,‘kw’)
tj=c.find_element(By.ID,‘su’)
tj.send_keys(Keys.CONTROL,‘c’) #复制
a.drag_and_drop(kw1,tj).perform()#从输入框拖动到搜索按钮
kw1.send_keys(Keys.CONTROL,‘v’)#粘贴
tj.send_keys(Keys.ENTER)
time.sleep(3)
c.close()
c.quit()

这里我们通过对事件的监控,进行复制和粘贴,这里涉及到一个组合键的知识,大家注意。

七、选项操作

我们可以通过给当前操作的对象一些选项来增强交互能力,如下:

from selenium import webdriver
from selenium.webdriver.common.by import By
import time
from selenium.webdriver.chrome.options import Options
o=Options()
o.add_argument(‘–headless’)#无界面浏览
c=webdriver.Chrome(executable_path=r’./chromedriver.exe’,chrome_options=o)
c.get(‘https://www.baidu.com’)
kw1=c.find_element(By.ID,‘kw’)
print(c.title)
time.sleep(3)
c.close()
c.quit()

web自动化测试框架-----Selenium大揭秘

这个时候就实现了咱们的无界面浏览了,也就是不用打开浏览器即可自动返回执行的结果。不过你可别以为选项就那么一两个,那可是多到你怀疑人生的,例如:

o.add_argument(‘–window-size=600,600’) #设置窗口大小
o.add_argument(‘–incognito’) #无痕模式
o.add_argument(‘–disable-infobars’) #去掉chrome正受到自动测试软件的控制的提示
o.add_argument(‘user-agent=“XXXX”’) #添加请求头
o.add_argument(“–proxy-server=http://200.130.123.43:3456”)#代理服务器访问
o.add_experimental_option(‘excludeSwitches’, [‘enable-automation’])#开发者模式
o.add_experimental_option(“prefs”,{“profile.managed_default_content_settings.images”: 2})#禁止加载图片
o.add_experimental_option(‘prefs’,
{‘profile.default_content_setting_values’:{‘notifications’:2}}) #禁用浏览器弹窗
o.add_argument(‘blink-settings=imagesEnabled=false’) #禁止加载图片
o.add_argument(‘lang=zh_CN.UTF-8’) #设置默认编码为utf-8
o.add_extension(create_proxyauth_extension(
proxy_host=‘host’,
proxy_port=‘port’,
proxy_username=“username”,
proxy_password=“password”
))# 设置有账号密码的代理
o.add_argument(‘–disable-gpu’) # 这个属性可以规避谷歌的部分bug
o.add_argument(‘–disable-javascript’) # 禁用javascript
o.add_argument(‘–hide-scrollbars’) # 隐藏滚动条
o.binary_location=r"C:\Users\Administrator\AppData\Local\Google\Chrome\Application" #指定浏览器位置 (可以考虑复制一个绿色版到项目,再指定)
o.add_argument(‘–no-sandbox’) #解决DevToolsActivePort文件不存在的报错

其实选项的添加无非就是分为以下这几种,如下:

o.set_headless() #设置启动无界面化
o.binary_location(value) #设置chrome二进制文件位置
o.add_argument(arg) #添加启动参数
o.add_extension(path) #添加指定路径下的扩展应用
o.add_encoded_extension(base64) #添加经过Base64编码的扩展应用
o.add_experimental_option(name,value) #添加实验性质的选项
o.debugger_address(value) #设置调试器地址
o.to_capabilities() #获取当前浏览器的所有信息

虽然选项很多,但是我们真正能用到的不多,一般就是无痕模式或者禁用JavaScript和图片来快速获取到相关信息。虽然我们上面使用的是Options方法,但是在实际应用中建议大家使用的ChromeOptions方法。

八、框架操作(Frame/IFrame)

我们还可以操作框架里的东西,比如IFrame,Frame等等,虽然都是框架,但是这两者操作起来还是有很大差别的。下面我们就来看看吧,如下:

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
一般就是无痕模式或者禁用JavaScript和图片来快速获取到相关信息。虽然我们上面使用的是Options方法,但是在实际应用中建议大家使用的ChromeOptions方法。

八、框架操作(Frame/IFrame)

我们还可以操作框架里的东西,比如IFrame,Frame等等,虽然都是框架,但是这两者操作起来还是有很大差别的。下面我们就来看看吧,如下:

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
[外链图片转存中…(img-SJO0zUyl-1713159849138)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值