python+selenium的web自动化】- 元素的常用操作详解(一)

 🔥 交流讨论:欢迎加入我们一起学习!

🔥 资源分享耗时200+小时精选的「软件测试」资料包

🔥 教程推荐:火遍全网的《软件测试》教程  

📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!

元素基本操作

常用操作

​ 关键代码🔻

  • 点击:ele.click()
  • 输入内容:ele.send_keys("内容")
  • 清空内容:ele.clear()
  • 获取文本内容:ele.text
  • 获取属性值:ele.get_attribute("属性名称")
  • 获取元素的宽高:ele.size,size和location一样都是实例属性,返回都是字典格式
  • 获取元素的坐标:ele.location,元素坐标值是通过元素的最左上角相对浏览器内容区域的左上角来定位的
python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#b18eb1"><em># 定位元素</em></span>
input_ele = driver.find_element_by_id(<span style="color:#98c379">"kw"</span>)
su_ele = driver.find_element_by_id(<span style="color:#98c379">"su"</span>)<span style="color:#b18eb1"><em># 获取元素的文本内容</em></span>
input_ele.text<span style="color:#b18eb1"><em># 获取元素的某个属性</em></span>
input_ele.get_attribute(<span style="color:#98c379">"属性名称"</span>)<span style="color:#b18eb1"><em># 输入内容</em></span>
input_ele.send_keys(<span style="color:#98c379">"selenium"</span>)<span style="color:#b18eb1"><em># 点击操作</em></span>
su_ele.click()<span style="color:#b18eb1"><em># 清空内容</em></span>
input_ele.clear()<span style="color:#b18eb1"><em># 获取元素的宽高</em></span>
<span style="color:#e6c07b">print</span>(<span style="color:#98c379">"【百度一下】按钮的宽高:{}"</span>.<span style="color:#e6c07b">format</span>(su_ele.size))<span style="color:#b18eb1"><em># 获取元素的x、y坐标值</em></span>
<span style="color:#e6c07b">print</span>(<span style="color:#98c379">"【百度一下】按钮的坐标:{}"</span>.<span style="color:#e6c07b">format</span>(su_ele.location))</span></span>

表单提交

​ 关键代码🔻

  • 表单提交:ele.submit(),用于表单的提交;也可以定位到具体提交按钮做一个点击的动作
python
<span style="background-color:#282c34"><span style="color:#abb2bf">input_ele = driver.find_element_by_id(<span style="color:#98c379">"kw"</span>)
input_ele.submit()	<span style="color:#b18eb1"><em># 也可以实现回车</em></span></span></span>

检查元素

​ 关键代码🔻

  • 是否可见:ele.is_displayed(),返回True可见,反之不可见
  • 是否可点击:ele.is_enabled(),返回True可点击,反之不可点击
  • 是否被选中:ele.is_selected(),返回True被选中,反之未选中
python
<span style="background-color:#282c34"><span style="color:#abb2bf">ele = driver.find_element_by_id(<span style="color:#98c379">"xxxx"</span>)
<span style="color:#e6c07b">print</span>(ele.is_displayed())
<span style="color:#e6c07b">print</span>(ele.is_enabled())
<span style="color:#e6c07b">print</span>(ele.is_selected())</span></span>

等待操作

​ 在web自动化中,不得不提的元素等待操作,我们在做功能测试中也会经常遇到页面元素未完全加载的情况,需要等到元素出现后再进行操作。现在是代码代替人工去做这件事,那自然也需要先等到元素加载完成才进行操作。

​ 当我们打开浏览器,进入一个网页driver.get(网址),除了get()会自主强制等待网页加载完再进入下一个操作,其他元素操作都不会自己等待页面加载完成,因此在get()之后只要我们做的动作会让页面产生变化就要做一个等待动作,以防元素未加载完成导致元素找不到报错,因为代码运行的速度是非常快的。

​ 有三种等待方式,一种强制等待,两种智能等待:隐性和显性。

强制等待

​ time.sleep(秒):表示让程序强制死等x秒,无论发生什么,都会在x秒之后再执行后续的代码

python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#f92672">import</span> time
time.sleep(<span style="color:#d19a66">2</span>)	<span style="color:#b18eb1"><em># 强制等待10s</em></span></span></span>

隐性等待

​ implicitly_wait(秒):设置最长等待时间,在这个时间内只要有个时间点加载完成,则执行下一步代码,如果在这个时间内仍未完成,就会抛出一个异常,在这整个driver的会话周期内,设置一次即可,全局都可用

​ 缺点🔶:程序会一直等待整个页面加载完成,也就是一般情况下你看到浏览器标签栏那个小圈不再转,才会执行下一步,但有时候页面想要的元素早就加载完成了,但是因为个别js、图片之类的东西特别慢,仍得等到页面全部完成才能执行下一步,就会增加不必要的加载时间

python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#f92672">from</span> selenium <span style="color:#f92672">import</span> webdriver<span style="color:#b18eb1"><em># 实例化chrome类</em></span>
<span style="color:#b18eb1"><em># 启动了Chromedriver,并与Chromedriver开启了会话</em></span>
driver = webdriver.Chrome()
driver.implicitly_wait(<span style="color:#d19a66">10</span>)driver.get(<span style="color:#98c379">"https://www.baidu.com"</span>)</span></span>

显性等待

​ 关键代码WebDriverWait(driver, 等待时长, 轮循周期).until/until_not(判断条件)

​ 使用WebDriverWait类和expected_conditions模块,它会明确等到某个条件满足后,再去执行下一步操作。它的等待机制是程序会每隔xx秒去寻找一遍,如果条件成立则执行下一步,否则以轮循的方式继续去寻找,直到超过设置的最长时间,然后抛出一个TimeoutException异常。

​ WebDriverWait类:显性等待类

​ expected_conditions模块,提供了一系列期望发生的条件,如下:

  • 🍊 title_is(title):判断当前页面的title是否等于预期,
  • 🍊 title_contains(title):判断当前页面的title是否包含预期字符串
  • 🍊 presence_of_element_located(locator):判断某个元素是否存在dom树
  • 🍊 visiblilty_of_element_located(locator):判断某个元素是否可见
  • 🍊 visiblilty_of(element):跟上面的方法一样,判断某个元素是否可见,只是前者要传locator(定位器),后者直接传定位到的element就好了
  • 🍊 element_to_be_clickable(locator):判断某个元素是否可点击
  • 🍊 frame_to_be_available_and_switch_to_it(frame下标/name属性/webelement对象):判断该frame是否可以swtich进去,可以则返回True并swtich进去,否则返回False。
  • 🍊 alert_is_present():判断页面上是否存在alert

​ 以上是列举的部分条件类,还有更多的方法有兴趣可以自行扩展。下面是其中一个方法示例:

python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#f92672">import</span> time
<span style="color:#f92672">from</span> selenium <span style="color:#f92672">import</span> webdriver
<span style="color:#f92672">from</span> selenium.webdriver.support.wait <span style="color:#f92672">import</span> WebDriverWait
<span style="color:#f92672">from</span> selenium.webdriver.support <span style="color:#f92672">import</span> expected_conditions <span style="color:#f92672">as</span> EC
<span style="color:#f92672">from</span> selenium.webdriver.common.by <span style="color:#f92672">import</span> By   <span style="color:#b18eb1"><em># By模块封装了8大定位方法名</em></span>driver = webdriver.Chrome()
<span style="color:#b18eb1"><em># driver.implicitly_wait(10)   # 智能等待10秒</em></span>driver.get(<span style="color:#98c379">"http://www.baidu.com"</span>)
driver.find_element_by_xpath(<span style="color:#98c379">'//div[@id="u1"]//a[@name="tj_login"]'</span>).click()<span style="color:#b18eb1"><em># 定位表达式</em></span>
loc = (By.ID, <span style="color:#98c379">"TANGRAM__PSP_10__footerULoginBtn"</span>)	<span style="color:#b18eb1"><em># 实际是11,这里改成10找不到会弹出报错</em></span>
<span style="color:#b18eb1"><em># 等待元素可见:等待时间10秒,轮循周期默认0.5秒一次</em></span>
WebDriverWait(driver, <span style="color:#d19a66">10</span>).until(EC.visibility_of_element_located(loc))<span style="color:#b18eb1"><em># 操作满足条件之后的元素</em></span>
driver.find_element(*loc).click()time.sleep(<span style="color:#d19a66">2</span>)
driver.quit()</span></span>

​ 运行结果:

shell
<span style="background-color:#282c34"><span style="color:#abb2bf">C:\software\python\python.exe D:/learn/test.py
Traceback (most recent call last):File "D:/learn/test.py", line 25, in <module>WebDriverWait(driver, 10).until(EC.visibility_of_element_located(loc))File "C:\software\python\lib\site-packages\selenium\webdriver\support\wait.py", line 80, in untilraise TimeoutException(message, screen, stacktrace)
selenium.common.exceptions.TimeoutException: Message: Process finished with exit code 1</span></span>

​ 知识点🔻

​ 上面提到的定位器其实就是一个元组(定位方式, 定位表达式),By模块里封装了8大定位方法名,跟我们之前的定位方式是一样的。

​ 不过要注意的是,在使用find_element() 定位元素时,不是传入一个元组,定位方式和表达式是直接作为参数传入的,因此上面的例子中会用到*解包。而find_element_by_id(属性值)之类的定位,底层代码用的其实就是find_element(),后者只要传对应定位方式的值,前者则需要传定位方式、定位表达式。

iframe切换

​ iframe:iframe就是一个网页里面嵌套了另外一个框架/页面,即一个html页面中,还内嵌了另一个html页面,这个内嵌的html页面放在<iframe></iframe>标签对中。iframe也是html中的某一个元素,里面放的是html页面。

切换到iframe

​ 如果我们要操作的元素,在内嵌的iframe页面中,那么必须要从当前页面切换到iframe中,然后再去iframe中的页面去操作元素。切换到iframe,主要有以下两种方式:

  • 🍅 方式一swtich_to.iframe()

​ 参数:iframe的index(下标)/ iframe的name属性 / iframe的webelement对象

python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#b18eb1"><em># 切换到iframe   下标/name属性/webelement对象</em></span>
driver.switch_to.iframe(<span style="color:#98c379">"login_frame_qq"</span>)
driver.switch_to.iframe(<span style="color:#d19a66">0</span>)
driver.switch_to.iframe(dirver.find_element_by_tag_name(<span style="color:#98c379">'iframe'</span>))</span></span>
  • 🍅 方式二EC.frame_to_be_available_and_switch_to_it()(强烈推荐 ,等待和切换一次到位)

​ 参数:iframe的index(下标)/ iframe的name属性 / iframe的webelement对象,等待条件:此方法会判断iframe是否可用,并且会自动切换到iframe中

python
<span style="background-color:#282c34"><span style="color:#abb2bf">wait = WebDriverWait(driver, <span style="color:#d19a66">10</span>)  <span style="color:#b18eb1"><em># 设置显性等待时间</em></span>
<span style="color:#b18eb1"><em># 设置等待条件,此方法会判断iframe是否可用,并且会自动切换到iframe中</em></span>
wait.until(EC.frame_to_be_available_and_switch_to_it(<span style="color:#98c379">'login_frame_qq'</span>))
driver.find_element_by_id(<span style="color:#98c379">'switcher_plogin'</span>).click()</span></span>

切换到上层iframe

​ 关键代码:driver.iframe_to.parent_frame()

​ 如果iframe中又内嵌了一个iframe,那就只能在主html中一层一层地切进去。如果想返回上一层时也是一层一层地返回去。一般很少会返回去。

切换到主html

​ 关键代码driver.swtich_to.default_content()

​ 切换到iframe之后,本身在主html就变成了在切换后的内嵌html,这时可以操作内嵌html的元素了,如果想重新操作主html的元素,就要先从iframe中回到主html。

​ 这里要注意,不管你是在第几层的iframe中,想切回到主html中,都只需执行一次。例子:

python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#f92672">import</span> time
<span style="color:#f92672">from</span> selenium <span style="color:#f92672">import</span> webdriver
<span style="color:#f92672">from</span> selenium.webdriver.support.wait <span style="color:#f92672">import</span> WebDriverWait
<span style="color:#f92672">from</span> selenium.webdriver.support <span style="color:#f92672">import</span> expected_conditions <span style="color:#f92672">as</span> EC
<span style="color:#f92672">from</span> selenium.webdriver.common.by <span style="color:#f92672">import</span> By<span style="color:#b18eb1"><em># 主html、内嵌html</em></span>
<span style="color:#b18eb1"><em># 确定要操作的元素是否在iframe内?</em></span>
<span style="color:#b18eb1"><em># 启动Chromedriver,并与Chromedriver开启会话</em></span>
driver = webdriver.Chrome()
driver.maximize_window()
driver.get(<span style="color:#98c379">"http://xxxx.com/"</span>)
driver.find_element_by_id(<span style="color:#98c379">'js_login'</span>).click()wait = WebDriverWait(driver, <span style="color:#d19a66">10</span>)  <span style="color:#b18eb1"><em># 设置显性等待时间</em></span>
qq_l = (By.XPATH, <span style="color:#98c379">'//div[@class="content-btns"]//a'</span>)
wait.until(EC.visibility_of_element_located(qq_l))  <span style="color:#b18eb1"><em># 设置显性等待条件</em></span>
driver.find_element(*qq_l).click()<span style="color:#b18eb1"><em># 设置等待条件,此方法会判断iframe是否可用,并且会自动切换到iframe中</em></span>
wait.until(EC.frame_to_be_available_and_switch_to_it(<span style="color:#98c379">'login_frame_qq'</span>))
driver.find_element_by_id(<span style="color:#98c379">'switcher_plogin'</span>).click()
driver.find_element_by_id(<span style="color:#98c379">'u'</span>).send_keys(<span style="color:#98c379">'test'</span>)
driver.find_element_by_id(<span style="color:#98c379">'p'</span>).send_keys(<span style="color:#98c379">'test'</span>)
driver.find_element_by_id(<span style="color:#98c379">'login_button'</span>).click()time.sleep(<span style="color:#d19a66">2</span>)
driver.quit()  <span style="color:#b18eb1"><em># 关闭浏览器,kill掉chromedriver进程</em></span></span></span>

alert弹出框操作

​ 网页上的弹出框分两种,一种是页面弹出框 ,这是一个html页面元素,可见时是能定位到并进行操作的;另一种则是alert弹出框,这是是js里的alert弹框,而selenium只能定位到html元素,那么像这种alert弹出框如何处理呢?既然是js那么我们就用js来处理。

页面弹出框

​ 它是一个html页面元素,只是需要由用户在页面的操作中触发弹出,因此处理这种类型的弹出框,一般分为两步:

  • 🍊 第一步:执行触发操作之后,等待弹出框出现
  • 🍊 第二步:定位弹出框中的元素并操作

​ 如百度登录的弹出框:

python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#f92672">import</span> time
<span style="color:#f92672">from</span> selenium <span style="color:#f92672">import</span> webdriver
<span style="color:#f92672">from</span> selenium.webdriver.support.wait <span style="color:#f92672">import</span> WebDriverWait
<span style="color:#f92672">from</span> selenium.webdriver.support <span style="color:#f92672">import</span> expected_conditions <span style="color:#f92672">as</span> EC
<span style="color:#f92672">from</span> selenium.webdriver.common.by <span style="color:#f92672">import</span> By   <span style="color:#b18eb1"><em># By模块封装了8大定位方法名</em></span>driver = webdriver.Chrome()driver.get(<span style="color:#98c379">"http://www.baidu.com"</span>)
driver.find_element_by_xpath(<span style="color:#98c379">'//div[@id="u1"]//a[@name="tj_login"]'</span>).click()<span style="color:#b18eb1"><em># 用户名登陆定位表达式</em></span>
loc = (By.ID, <span style="color:#98c379">"TANGRAM__PSP_11__footerULoginBtn"</span>)
<span style="color:#b18eb1"><em># 等待时间10秒,轮循周期默认0.5秒一次</em></span>
WebDriverWait(driver, <span style="color:#d19a66">10</span>).until(EC.visibility_of_element_located(loc))<span style="color:#b18eb1"><em># 操作满足条件之后的元素</em></span>
driver.find_element(*loc).click()time.sleep(<span style="color:#d19a66">2</span>)
driver.quit()</span></span>

alert弹出框

​ alert弹出框的处理方式:

  • 🍰 第一步:使用swtich_to.alert切换到弹出框,建议先使用显性等待EC.alert_is_present()判断弹出框是否可见,或者强制等待0.5s:time.sleep(0.5)
  • 🍰 第二步:使用Alert类提供的一系列操作方法对弹窗进行操作:
    • accept() 是
    • dismiss() 否
    • Send_keys() 往弹出框里输入文本
    • text() 获取弹框里的内容
python
<span style="background-color:#282c34"><span style="color:#abb2bf"><span style="color:#f92672">import</span> time
<span style="color:#f92672">from</span> selenium <span style="color:#f92672">import</span> webdriver
<span style="color:#f92672">from</span> selenium.webdriver.support.wait <span style="color:#f92672">import</span> WebDriverWait
<span style="color:#f92672">from</span> selenium.webdriver.support <span style="color:#f92672">import</span> expected_conditions <span style="color:#f92672">as</span> EC<span style="color:#b18eb1"><em># 启动Chromedriver,并与Chromedriver开启会话</em></span>
driver = webdriver.Chrome()
driver.maximize_window()
driver.get(<span style="color:#98c379">"https://www.w3school.com.cn/tiy/t.asp?f=js_alert"</span>)wait = WebDriverWait(driver, <span style="color:#d19a66">10</span>)
wait.until(EC.frame_to_be_available_and_switch_to_it(<span style="color:#98c379">'iframeResult'</span>))
<span style="color:#b18eb1"><em># 触发alert弹框</em></span>
driver.find_element_by_xpath(<span style="color:#98c379">'//button[text()="试一试"]'</span>).click()
wait.until(EC.alert_is_present())time.sleep(<span style="color:#d19a66">3</span>)   <span style="color:#b18eb1"><em># 这里是为了看下效果</em></span>
alert = driver.switch_to.alert  <span style="color:#b18eb1"><em># Alert类的实例化,切换到alert</em></span>
alert.accept()   <span style="color:#b18eb1"><em># 是</em></span>
<span style="color:#b18eb1"><em># dismiss()     否</em></span>
<span style="color:#b18eb1"><em># text()	    获取弹框里的内容</em></span>
<span style="color:#b18eb1"><em># Send_keys()   往弹出框里输入文本</em></span>driver.quit()</span></span>

最后我邀请你进入我们的【软件测试学习交流群:785128166】, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路

作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:程序员二黑】自提!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/660618.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

旷视low-level系列(二):Practical Deep Raw Image Denoising on Mobile Devices

论文&#xff1a;ECCV 2020 代码&#xff1a;https://github.com/MegEngine/PMRID 文章目录 1. Motivation2. Contribution3. Methods3.1 噪声建模&参数估计3.2 k-Sigma变换3.3 移动端友好的网络结构 4. Experiments5. Comments 1. Motivation 业内周知&#xff0c;基于深…

信息安全管理体系

本文已收录至《全国计算机等级考试——信息 安全技术》专栏 信息安全管理体系&#xff08;Information Security Management Systems&#xff09;是组织在整体或特定范围内建立信息安全方针和目标&#xff0c;以及完成这些目标所用方法的体系。它是直接管理活动的结果&#xff…

力扣经典题:用栈表示队列

1.在元素入栈完成时&#xff0c;再出栈进入到另一个栈的时候&#xff0c;另一个栈的栈顶元素就是队列的队尾元素 2.初始化操作完全与上一题相同 3.peek函数的实现&#xff1a;将1的思路写出来&#xff0c;再返回第二个队列的栈顶元素 4.pop函数就是将peek函数进行实现后将to…

[嵌入式软件][启蒙篇][仿真平台] STM32F103实现SPI控制OLED屏幕

上一篇&#xff1a; [嵌入式软件][启蒙篇][仿真平台] STM32F103实现LED、按键 [嵌入式软件][启蒙篇][仿真平台] STM32F103实现串口输出输入、ADC采集 [嵌入式软件][启蒙篇][仿真平台]STM32F103实现定时器 [嵌入式软件][启蒙篇][仿真平台] STM32F103实现IIC控制OLED屏幕 文章目…

HIS预约挂号系统源码 看病挂号快人一步

提到去大型医院机构就诊时&#xff0c;许多人都感到恐惧。有些人一旦走进医院的门诊大厅&#xff0c;就感到迷茫&#xff0c;既无法理解导医台医生的建议&#xff0c;也找不到应该去哪个科室进行检查。实际上&#xff0c;就医也是一门学问&#xff0c;如何优化时间分配&#xf…

AIGC专题:从0到1精益创新 AIGC产品应用及商业化落地实践

今天分享的是AIGC系列深度研究报告&#xff1a;《AIGC专题&#xff1a;从0到1精益创新 AIGC产品应用及商业化落地实践》。 &#xff08;报告出品方&#xff1a;易点天下&#xff09; 报告共计&#xff1a;38页 企业内部增效-AI知识库 企业内部IT、运维、人力资源、行政等等日…

都 2024 年了!程序员的到底出路在哪里!?继续卷技术?晋升管理层?还是转业?

都 2024 年了&#xff01;程序员的到底出路在哪里&#xff01;&#xff1f;继续卷技术&#xff1f;晋升管理层&#xff1f;还是转业&#xff1f; 1&#xff09;程序员的难处2&#xff09;程序员专业方向3&#xff09;大数据3.1.大数据开发涉及到哪些技术3.2.大数据开发涉及到的…

C语言assert断言详解指针(3)

各位少年&#xff0c;大家好&#xff0c;我是博主那一脸阳光&#xff0c;今天分享assert法官的断言&#xff0c;指针宝箱的使用。 前言&#xff1a;如果你在计算机的世界中触犯了语法法规&#xff0c;那么编译器就要上线了&#xff0c;就会出现报错。然而想想我们在现实中设计到…

仰暮计划|“一周一顿的玉米面和白面蒸的糕点,是当时所能吃到的极好的食物”

平淡又记忆深刻的一生 口述人&#xff1a;元奶奶 整理人&#xff1a;宋佳音 口述人基本信息&#xff1a;女 出生于1958年&#xff0c;今年65周岁&#xff0c;祖籍东北&#xff0c;现定居于上海&#xff0c;已从制药厂退休十余年。 元奶奶的自述&#xff1a; 我出生于1958年…

B样条基函数

​定义&#xff1a;令U{u0,u1,…,um}是一个单调不减的实数序列&#xff0c;即ui≤ui1&#xff0c;i0&#xff0c;1&#xff0c;…&#xff0c;m-1。其中&#xff0c;ui称为节点&#xff0c;U称为节点矢量&#xff0c;用Ni,p(u)表示第i个p次&#xff08;p1阶&#xff09;B样条基…

asp.net core通过读取配置文件来动态生成接口

如果希望接口是每次通过配置文件生成的&#xff0c;这样设计一些低代码的方式来获得接口。 系统目录结构&#xff1a; 启动配置代码&#xff1a; using Microsoft.AspNetCore.Hosting; using System.Configuration; using System.Data.Entity; using Swashbuckle.AspNetCore.…

[Python] 什么是PCA降维技术以及scikit-learn中PCA类使用案例(图文教程,含详细代码)

什么是维度&#xff1f; 对于Numpy中数组来说&#xff0c;维度就是功能shape返回的结果&#xff0c;shape中返回了几个数字&#xff0c;就是几维。索引以外的数据&#xff0c;不分行列的叫一维&#xff08;此时shape返回唯一的维度上的数据个数&#xff09;&#xff0c;有行列…

【学网攻】 第(14)节 -- 动态路由(EIGRP)

系列文章目录 目录 系列文章目录 文章目录 前言 一、动态路由EIGRP是什么&#xff1f; 二、实验 1.引入 实验步骤 实验拓扑图 实验配置 看到D开头是便是我们的EIGRP动态路由 总结 文章目录 【学网攻】 第(1)节 -- 认识网络【学网攻】 第(2)节 -- 交换机认识及使用【学…

阿里云智能集团副总裁安筱鹏:企业数字化的终局是什么?

以下文章来源于数字化企业 &#xff0c;作者安筱鹏博士 回答数字化终局追问的起点是&#xff0c;企业需要重新定义我是谁。成为有竞争力的行业领导厂商&#xff0c;你应当成为一个客户运营商&#xff0c;即能够实时洞察、实时满足客户需求&#xff0c;追求极致的客户体验。而要…

版本管理工具git: 谨慎使用git中的撤回操作

文章目录 一、背景二、解决方案1、步骤一2、步骤二 三、参考 一、背景 昨天代码分支提交错了&#xff0c;idea中使用了如下操作&#xff0c;结果代码不见了 二、解决方案 1、步骤一 使用git reflog命令&#xff0c;查看提交记录&#xff0c;找到之前commit操作的哈希值 …

雾锁王国Enshrouded个人专服怎么搭建?怎么多人联机一起玩?

前面跟大家分享了『零基础也可以10秒开服幻兽帕鲁&#xff0c;只需要鼠标点击几下即可自动部署』一文&#xff0c;大家可以快速搭建属于自己的幻兽帕鲁专服。现在我们同样可以在10秒搭建雾锁王国专服&#xff0c;让您与朋友一起合作战胜强大的Boss。 雾锁王国&#xff1a;你是火…

Docker本地部署可编辑开源导航页并发布公网分享好友可访问

文章目录 1. 使用Docker搜索镜像2. 下载镜像3. 查看镜像4. 启动容器5. 浏览器访问6. 远程访问6.1 内网穿透工具安装6.2 创建远程连接公网地址6.3 使用固定二级子域名地址远程访问 今天和大家分享如何使用Docker本地部署一个开源的简约风格网址导航页&#xff0c;支持五种搜索引…

基于C++的面向对象程序设计:类与对象的深入剖析

面向对象程序设计的基本特点 面向对象程序设计的基本特点包括&#xff1a;抽象、封装、继承、多态。 抽象 抽象是指对具体问题或对象进行概括&#xff0c;抽出其公共性质并加以描述的过程。一般情况抽象分为数据抽象和行为抽象&#xff0c;其中数据抽象是指一个对象区别于另…

C++/数据结构:二叉搜索树的实现与应用

目录 一、二叉搜索树简介 二、二叉搜索树的结构与实现 2.1二叉树的查找与插入 2.2二叉树的删除 2.3二叉搜索树的实现 2.3.1非递归实现 2.3.2递归实现 三、二叉搜索树的k模型和kv模型 一、二叉搜索树简介 二叉搜索树又称二叉排序树&#xff0c;它或者是一棵空树&#xff0…

IDEA的properties默认编码是UTF-8但是不显示中文

问题描述 今天打开IDEA项目&#xff0c;发现messages_zh_CN.properties不显示中文了 但奇怪的是target下的文件就是展示的中文 而且我IDEA已经配置了编码格式是UTF-8了 使用nodepad打开源文件&#xff0c;也是展示编码格式是UTF-8 &#xff08;打开target下的文件&#xff0c;…