【教程】新的Selenium!整合了隐藏浏览器指纹等功能

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn]

如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~

目录

前景提要

driver = Driver()

常用driver 接口

最后的话


前景提要

        新的selenium,整合了隐藏浏览器指纹,非常好用:

GitHub - seleniumbase/SeleniumBase📊 Python's all-in-one framework for web crawling, scraping, testing, and reporting. Supports pytest. UC Mode provides stealth. Includes many tools. - seleniumbase/SeleniumBaseicon-default.png?t=N7T8https://github.com/seleniumbase/SeleniumBase        虽然官方的例程比较多,但相关文档的说明和解释不是很完善,所以这里简单记录一下常用的,以便查阅。本内容将根据我用到的内容不断更新。


driver = Driver()

        比如可以这样用:

driver = Driver(browser="chrome", headless2=False, proxy="127.0.0.1:7890", undetectable=True, incognito=True, enable_3d_apis=False, do_not_track=True, binary_location="./chrome.exe", driver_version="./chromedriver.exe", page_load_strategy="normal",)

        这是一个复杂的函数定义,用于配置和启动一个基于 Selenium 的浏览器驱动程序(如 Chrome、Edge、Firefox 或 Safari)。每个参数都提供了不同的配置选项,允许用户定制浏览器的行为和特性。以下是每个参数的详细解释:

def Driver(# 选择使用的浏览器类型,包括 "chrome"、"edge"、"firefox" 或 "safari"。browser=None,# 使用原始的无头模式(适用于 Chromium 和 Firefox)。headless=None,# Chromium 的新无头模式(具有更多功能)。headless2=None,# 在 Linux 上以有头/GUI 模式运行测试,非默认选项。headed=None,# 设置浏览器的语言区域代码。locale_code=None,# Selenium Grid 协议,选项为 "http" 或 "https"。protocol=None,# 用于测试的 Selenium Grid 服务器或 IP。servername=None,# 测试服务器使用的 Selenium Grid 端口。port=None,# 使用代理服务器。格式为 "SERVER:PORT" 或 "USER:PASS@SERVER:PORT"。proxy=None,# 在使用代理时跳过的域列表。proxy_bypass_list=None,# 使用 PAC 文件。格式为 URL 或 "USERNAME:PASSWORD@URL"。proxy_pac_url=None,# 在多线程情况下允许多个具有身份验证的代理。multi_proxy=False,# 修改浏览器的 User-Agent 字符串。agent=None,# 与 Selenium Grid 一起使用的期望能力文件。cap_file=None,# 与 Selenium Grid 一起使用的期望能力字符串。cap_string=None,# 启用 SeleniumBase Recorder 的 Chromium 扩展。recorder_ext=None,# 禁用网站的 JavaScript。页面可能会因此中断。disable_js=None,# 禁用网站的内容安全策略。disable_csp=None,# 在基于 Chromium 的浏览器上启用 Web 安全性。enable_ws=None,# 禁用 Web 安全性(与 enable_ws 相反,None 和 False 有区别)。disable_ws=None,# 在网站上启用 Chrome 同步。enable_sync=None,# 使用 Chrome 的自动化扩展。use_auto_ext=None,# 使用 undetected-chromedriver 以规避反机器人检测。undetectable=None,# 在 undetected-chromedriver 模式下捕获 CDP 事件。uc_cdp_events=None,# 使用 undetected-chromedriver 作为子进程。uc_subprocess=None,# 捕获 CDP 事件("performance": "ALL", "browser": "ALL")。log_cdp_events=None,# 弃用参数 - "--no-sandbox" 现在总是使用。no_sandbox=None,# 弃用参数 - 如果不是 "swiftshader",GPU 会被禁用。disable_gpu=None,# 启用 Chromium 的隐身模式。incognito=None,# 启用 Chromium 的访客模式。guest_mode=None,# 启用 Chromium 的黑暗模式。dark_mode=None,# 在浏览器打开时启用 Chromium 的开发者工具。devtools=None,# 在 "http://localhost:9222" 启用 Chrome 的调试器。remote_debug=None,# 启用 WebGL 和 3D APIs。enable_3d_apis=None,# 启用 Chrome 的 swiftshader(--use-gl=angle / --use-angle=swiftshader-webgl)。swiftshader=None,# 屏蔽某些类型的显示广告。ad_block_on=None,# 设置主机解析规则,用逗号分隔。host_resolver_rules=None,# 在测试期间阻止图像加载。block_images=None,# 告诉网站您不想被跟踪。do_not_track=None,# 设置 Chromium 参数,用逗号分隔。chromium_arg=None,# 设置 Firefox 参数,用逗号分隔。firefox_arg=None,# 设置 Firefox 首选项和值,用逗号分隔。firefox_pref=None,# 设置 Chrome 用户数据目录。user_data_dir=None,# 加载 Chrome 扩展 .zip 或 .crx 文件,用逗号分隔。extension_zip=None,# 加载 Chrome 扩展目录,用逗号分隔。extension_dir=None,# 禁用 Chrome 特性,用逗号分隔。disable_features=None,# 设置要使用的 Chromium 浏览器二进制文件路径。binary_location=None,# 设置 chromedriver 或 uc_driver 的版本。driver_version=None,# 设置 Chrome 页面加载策略,选项为 "normal"、"eager" 或 "none"。page_load_strategy=None,# 使用 selenium-wire 的 webdriver 代替 selenium webdriver。use_wire=None,# 设置 Chrome "plugins.always_open_pdf_externally": True。external_pdf=None,# 在运行测试时使用移动设备模拟器。is_mobile=None,# is_mobile 的快捷方式/重复项。mobile=None,# 设置设备宽度。d_width=None,# 设置设备高度。d_height=None,# 设置设备像素比。d_p_r=None,# undetectable 的快捷方式/重复项。uc=None,# undetectable 的快捷方式/重复项。undetected=None,# uc_cdp_events 的快捷方式/重复项。uc_cdp=None,# uc_subprocess 的快捷方式/重复项。uc_sub=None,# log_cdp_events 的快捷方式/重复项。log_cdp=None,# ad_block_on 的快捷方式/重复项。ad_block=None,# servername 的快捷方式/重复项。server=None,# guest_mode 的快捷方式/重复项。guest=None,# use_wire 的快捷方式/重复项。wire=None,# page_load_strategy 的快捷方式/重复项。pls=None,
):

常用driver 接口

method_summary.md

        接口函数定义:

self.open(url)
# 打开指定的 URL。
# 其他命名方式: self.open_url(url), self.visit(url), visit_url(url), self.goto(url), self.go_to(url)self.get(url)
# 如果参数是 URL,则执行 self.open(url)。
# 否则返回 self.get_element(URL_AS_A_SELECTOR)。self.click(selector, by="css selector", timeout=None, delay=0, scroll=True)
# 点击指定的元素。self.slow_click(selector, by="css selector", timeout=None)
# 缓慢点击指定的元素。self.double_click(selector, by="css selector", timeout=None)
# 双击指定的元素。self.context_click(selector, by="css selector", timeout=None)
# 右键点击指定的元素。
# 其他命名方式: self.right_click(selector, by="css selector", timeout=None)self.click_chain(selectors_list, by="css selector", timeout=None, spacing=0)
# 按顺序点击一组元素。self.type(selector, text, by="css selector", timeout=None)
# 在指定的元素中输入文本。
# 其他命名方式: self.update_text(selector, text, by="css selector", timeout=None), self.input(selector, text, by="css selector", timeout=None), self.fill(selector, text, by="css selector", timeout=None), self.write(selector, text, by="css selector", timeout=None)self.send_keys(selector, text, by="css selector", timeout=None)
# 向指定的元素发送键盘输入。
# 其他命名方式: self.add_text(selector, text, by="css selector", timeout=None)self.press_keys(selector, text, by="css selector", timeout=None)
# 向指定的元素发送键盘按键。self.submit(selector, by="css selector")
# 提交指定的表单。self.clear(selector, by="css selector", timeout=None)
# 清除指定元素的内容。self.focus(selector, by="css selector", timeout=None)
# 聚焦到指定的元素。self.refresh()
# 刷新当前页面。
# 其他命名方式: self.refresh_page(), self.reload_page(), self.reload()self.get_current_url()
# 获取当前页面的 URL。self.get_origin()
# 获取当前页面的原始 URL。self.get_page_source()
# 获取当前页面的源代码。self.get_title()
# 获取当前页面的标题。
# 其他命名方式: self.get_page_title()self.get_user_agent()
# 获取浏览器的用户代理字符串。self.get_locale_code()
# 获取浏览器的语言区域代码。self.go_back()
# 导航到浏览器历史记录的上一页。self.go_forward()
# 导航到浏览器历史记录的下一页。self.open_start_page()
# 打开初始页面。self.open_if_not_url(url)
# 如果当前 URL 不是指定的 URL,则打开它。self.is_element_present(selector, by="css selector")
# 检查指定的元素是否存在。self.is_element_visible(selector, by="css selector")
# 检查指定的元素是否可见。self.is_element_clickable(selector, by="css selector")
# 检查指定的元素是否可点击。self.is_element_enabled(selector, by="css selector")
# 检查指定的元素是否启用。self.is_text_visible(text, selector="html", by="css selector")
# 检查指定的文本在元素中是否可见。self.is_exact_text_visible(text, selector="html", by="css selector")
# 检查指定的精确文本在元素中是否可见。self.is_non_empty_text_visible(selector="html", by="css selector")
# 检查指定的元素是否包含非空文本。self.is_attribute_present(selector, attribute, value=None, by="css selector")
# 检查指定的元素是否具有指定的属性和值。self.is_link_text_visible(link_text)
# 检查指定的链接文本是否可见。self.is_partial_link_text_visible(partial_link_text)
# 检查指定的部分链接文本是否可见。self.is_link_text_present(link_text)
# 检查指定的链接文本是否存在。self.is_partial_link_text_present(link_text)
# 检查指定的部分链接文本是否存在。self.get_link_attribute(link_text, attribute, hard_fail=True)
# 获取指定链接文本的属性值。
# 其他命名方式: self.get_link_text_attribute(link_text, attribute, hard_fail=True)self.get_partial_link_text_attribute(link_text, attribute, hard_fail=True)
# 获取指定部分链接文本的属性值。self.click_link(link_text, timeout=None)
# 点击指定的链接文本。
# 其他命名方式: self.click_link_text(link_text, timeout=None)self.click_partial_link(partial_link_text, timeout=None)
# 点击指定的部分链接文本。
# 其他命名方式: self.click_partial_link_text(partial_link_text, timeout=None)self.get_text(selector="html", by="css selector", timeout=None)
# 获取指定元素的文本内容。self.get_attribute(selector, attribute, by="css selector", timeout=None, hard_fail=True)
# 获取指定元素的属性值。self.set_attribute(selector, attribute, value, by="css selector", timeout=None, scroll=False)
# 设置指定元素的属性值。self.set_attributes(selector, attribute, value, by="css selector")
# 设置多个元素的属性值。
# 其他命名方式: self.set_attribute_all(selector, attribute, value, by="css selector")self.remove_attribute(selector, attribute, by="css selector", timeout=None)
# 移除指定元素的属性。self.remove_attributes(selector, attribute, by="css selector")
# 移除多个元素的属性。self.get_property(selector, property, by="css selector", timeout=None)
# 获取指定元素的属性值。self.get_text_content(selector="html", by="css selector", timeout=None)
# 获取指定元素的文本内容。self.get_property_value(selector, property, by="css selector", timeout=None)
# 获取指定元素的属性值。self.get_image_url(selector, by="css selector", timeout=None)
# 获取指定图像元素的 URL。self.find_elements(selector, by="css selector", limit=0)
# 查找所有匹配的元素。self.find_visible_elements(selector, by="css selector", limit=0)
# 查找所有可见的匹配元素。self.click_visible_elements(selector, by="css selector", limit=0, timeout=None)
# 点击所有可见的匹配元素。self.click_nth_visible_element(selector, number, by="css selector", timeout=None)
# 点击第 N 个可见的匹配元素。self.click_if_visible(selector, by="css selector", timeout=0)
# 如果元素可见则点击。self.click_active_element()
# 点击当前活动元素。self.click_with_offset(selector, x, y, by="css selector", mark=None, timeout=None, center=None)
# 点击元素的指定偏移位置。self.double_click_with_offset(selector, x, y, by="css selector", mark=None, timeout=None, center=None)
# 双击元素的指定偏移位置。self.is_checked(selector, by="css selector", timeout=None)
# 检查指定的复选框是否被选中。
# 其他命名方式: self.is_selected(selector, by="css selector", timeout=None)self.check_if_unchecked(selector, by="css selector")
# 如果复选框未选中则选中。
# 其他命名方式: self.select_if_unselected(selector, by="css selector")self.uncheck_if_checked(selector, by="css selector")
# 如果复选框被选中则取消选中。
# 其他命名方式: self.unselect_if_selected(selector, by="css selector")self.is_element_in_an_iframe(selector, by="css selector")
# 检查指定元素是否在 iframe 中。self.switch_to_frame_of_element(selector, by="css selector")
# 切换到包含指定元素的 iframe。self.hover(selector, by="css selector", timeout=None)
# 悬停在指定元素上。
# 其他命名方式: self.hover_on_element(selector, by="css selector", timeout=None), self.hover_over_element(selector, by="css selector", timeout=None)self.hover_and_click(hover_selector, click_selector,hover_by="css selector", click_by="css selector",timeout=None, js_click=False)
# 悬停在一个元素上然后点击另一个元素。self.hover_and_js_click(hover_selector, click_selector,hover_by="css selector", click_by="css selector",timeout=None)
# 悬停在一个元素上然后使用 JavaScript 点击另一个元素。self.hover_and_double_click(hover_selector, click_selector,hover_by="css selector", click_by="css selector",timeout=None)
# 悬停在一个元素上然后双击另一个元素。self.drag_and_drop(drag_selector, drop_selector,drag_by="css selector", drop_by="css selector",timeout=None, jquery=False)
# 拖动一个元素并放置到另一个元素上。self.drag_and_drop_with_offset(selector, x, y, by="css selector", timeout=None)
# 拖动元素到指定的偏移位置。self.select_option_by_text(dropdown_selector, option, dropdown_by="css selector", timeout=None)
# 通过文本选择下拉选项。self.select_option_by_index(dropdown_selector, option, dropdown_by="css selector", timeout=None)
# 通过索引选择下拉选项。self.select_option_by_value(dropdown_selector, option, dropdown_by="css selector", timeout=None)
# 通过值选择下拉选项。self.get_select_options(dropdown_selector, attribute="text", by="css selector", timeout=None)
# 获取下拉选项的属性值。self.load_html_string(html_string, new_page=True)
# 加载 HTML 字符串。self.set_content(html_string, new_page=False)
# 设置 HTML 内容。self.load_html_file(html_file, new_page=True)
# 加载 HTML 文件。self.open_html_file(html_file)
# 打开 HTML 文件。self.execute_script(script, *args, **kwargs)
# 执行 JavaScript 脚本。self.execute_cdp_cmd(script, *args, **kwargs)
# 执行 Chrome DevTools 协议命令。self.execute_async_script(script, timeout=None)
# 执行异步 JavaScript 脚本。self.safe_execute_script(script, *args, **kwargs)
# 安全执行 JavaScript 脚本。self.get_gui_element_rect(selector, by="css selector")
# 获取 GUI 元素的矩形。self.get_gui_element_center(selector, by="css selector")
# 获取 GUI 元素的中心点。self.get_window_rect()
# 获取浏览器窗口的矩形。self.get_window_size()
# 获取浏览器窗口的大小。self.get_window_position()
# 获取浏览器窗口的位置。self.set_window_rect(x, y, width, height)
# 设置浏览器窗口的矩形。self.set_window_size(width, height)
# 设置浏览器窗口的大小。self.set_window_position(x, y)
# 设置浏览器窗口的位置。self.maximize_window()
# 最大化浏览器窗口。self.switch_to_frame(frame="iframe", timeout=None)
# 切换到指定的 iframe。self.switch_to_default_content()
# 切换到默认内容(退出 iframe)。self.switch_to_parent_frame()
# 切换到父 iframe。with self.frame_switch(frame, timeout=None):# 使用上下文管理器切换到指定的 iframe。self.set_content_to_frame(frame, timeout=None)
# 设置内容到指定的 iframe。self.set_content_to_default(nested=False)
# 设置内容到默认(退出 iframe)。
# 其他命名方式: self.set_content_to_default_content(nested=False)self.set_content_to_parent()
# 设置内容到父 iframe。
# 其他命名方式: self.set_content_to_parent_frame()self.open_new_window(switch_to=True)
# 打开新窗口。
# 其他命名方式: self.open_new_tab(switch_to=True)self.switch_to_window(window, timeout=None)
# 切换到指定的窗口。
# 其他命名方式: self.switch_to_tab(tab, timeout=None)self.switch_to_default_window()
# 切换到默认窗口。
# 其他命名方式: self.switch_to_default_tab()self.switch_to_newest_window()
# 切换到最新的窗口。
# 其他命名方式: self.switch_to_newest_tab()self.get_new_driver(browser=None,headless=None,locale_code=None,protocol=None,servername=None,port=None,proxy=None,proxy_bypass_list=None,proxy_pac_url=None,multi_proxy=None,agent=None,switch_to=True,cap_file=None,cap_string=None,recorder_ext=None,disable_js=None,disable_csp=None,enable_ws=None,enable_sync=None,use_auto_ext=None,undetectable=None,uc_cdp_events=None,uc_subprocess=None,log_cdp_events=None,no_sandbox=None,disable_gpu=None,headless2=None,incognito=None,guest_mode=None,dark_mode=None,devtools=None,remote_debug=None,enable_3d_apis=None,swiftshader=None,ad_block_on=None,host_resolver_rules=None,block_images=None,do_not_track=None,chromium_arg=None,firefox_arg=None,firefox_pref=None,user_data_dir=None,extension_zip=None,extension_dir=None,disable_features=None,binary_location=None,driver_version=None,page_load_strategy=None,use_wire=None,external_pdf=None,is_mobile=None,d_width=None,d_height=None,d_p_r=None,
)
# 获取新的 WebDriver 实例。self.switch_to_driver(driver)
# 切换到指定的 WebDriver 实例。self.switch_to_default_driver()
# 切换到默认的 WebDriver 实例。self.save_screenshot(name, folder=None, selector=None, by="css selector")
# 保存当前页面的截图。self.save_screenshot_to_logs(name=None, selector=None, by="css selector")
# 保存截图到日志。self.save_data_to_logs(data, file_name=None)
# 保存数据到日志。self.append_data_to_logs(data, file_name=None)
# 附加数据到日志。self.save_page_source(name, folder=None)
# 保存页面源代码。self.save_cookies(name="cookies.txt")
# 保存浏览器 cookies。self.load_cookies(name="cookies.txt")
# 加载浏览器 cookies。self.delete_all_cookies()
# 删除所有浏览器 cookies。
# 其他命名方式: self.clear_all_cookies()self.delete_saved_cookies(name="cookies.txt")
# 删除保存的 cookies。self.get_saved_cookies(name="cookies.txt")
# 获取保存的 cookies。self.get_cookie(name)
# 获取指定名称的 cookie。self.get_cookies()
# 获取所有 cookies。self.add_cookie(cookie_dict)
# 添加单个 cookie。self.add_cookies(cookies)
# 添加多个 cookies。self.wait_for_ready_state_complete(timeout=None)
# 等待页面加载完成。self.wait_for_angularjs(timeout=None)
# 等待 AngularJS 加载完成。self.sleep(seconds)
# 暂停指定的秒数。
# 其他命名方式: self.wait(seconds)self.install_addon(xpi_file)
# 安装浏览器插件。self.activate_jquery()
# 激活 jQuery。self.activate_demo_mode()
# 启用演示模式。self.deactivate_demo_mode()
# 禁用演示模式。self.activate_design_mode()
# 启用设计模式。self.deactivate_design_mode()
# 禁用设计模式。self.activate_recorder()
# 启用记录器。self.save_recorded_actions()
# 保存记录的操作。self.bring_active_window_to_front()
# 将活动窗口置于前台。self.bring_to_front(selector, by="css selector")
# 将指定元素置于前台。self.highlight_click(selector, by="css selector", loops=3, scroll=True, timeout=None)
# 高亮点击指定的元素。self.highlight_type(selector, text, by="css selector", loops=3, scroll=True, timeout=None)
# 高亮输入文本到指定的元素。
# 其他命名方式: self.highlight_update_text(selector, text, by="css selector", loops=3, scroll=True, timeout=None)self.highlight_if_visible(selector, by="css selector", loops=4, scroll=True)
# 如果元素可见则高亮。self.highlight(selector, by="css selector", loops=4, scroll=True, timeout=None)
# 高亮指定的元素。self.highlight_elements(selector, by="css selector", loops=4, scroll=True, limit=0)
# 高亮所有匹配的元素。self.press_up_arrow(selector="html", times=1, by="css selector")
# 按上箭头键。self.press_down_arrow(selector="html", times=1, by="css selector")
# 按下箭头键。self.press_left_arrow(selector="html", times=1, by="css selector")
# 按左箭头键。self.press_right_arrow(selector="html", times=1, by="css selector")
# 按右箭头键。self.scroll_to(selector, by="css selector", timeout=None)
# 滚动到指定的元素。
# 其他命名方式: self.scroll_to_element(selector, by="css selector")self.slow_scroll_to(selector, by="css selector", timeout=None)
# 缓慢滚动到指定的元素。
# 其他命名方式: self.slow_scroll_to_element(selector, by="css selector")self.scroll_into_view(selector, by="css selector", timeout=None)
# 滚动到视图中的指定元素。self.scroll_to_top()
# 滚动到页面顶部。self.scroll_to_bottom()
# 滚动到页面底部。self.click_xpath(xpath)
# 点击指定的 XPath 元素。self.js_click(selector, by="css selector", all_matches=False, timeout=None, scroll=True)
# 使用 JavaScript 点击指定的元素。self.js_click_if_present(selector, by="css selector", timeout=0)
# 如果元素存在则使用 JavaScript 点击。self.js_click_if_visible(selector, by="css selector", timeout=0)
# 如果元素可见则使用 JavaScript 点击。self.js_click_all(selector, by="css selector", timeout=None)
# 使用 JavaScript 点击所有匹配的元素。self.jquery_click(selector, by="css selector", timeout=None)
# 使用 jQuery 点击指定的元素。self.jquery_click_all(selector, by="css selector", timeout=None)
# 使用 jQuery 点击所有匹配的元素。self.hide_element(selector, by="css selector")
# 隐藏指定的元素。self.hide_elements(selector, by="css selector")
# 隐藏所有匹配的元素。self.show_element(selector, by="css selector")
# 显示指定的元素。self.show_elements(selector, by="css selector")
# 显示所有匹配的元素。self.remove_element(selector, by="css selector")
# 移除指定的元素。self.remove_elements(selector, by="css selector")
# 移除所有匹配的元素。self.ad_block()
# 启用广告拦截。
# 其他命名方式: self.block_ads()self.show_file_choosers()
# 显示文件选择器。self.disable_beforeunload()
# 禁用 beforeunload 事件。self.get_domain_url(url)
# 获取指定 URL 的域名。self.get_active_element_css()
# 获取当前活动元素的 CSS。self.get_beautiful_soup(source=None)
# 获取 BeautifulSoup 对象。self.get_unique_links()
# 获取页面中的唯一链接。self.get_link_status_code(link, allow_redirects=False, timeout=5, verify=False)
# 获取指定链接的状态码。self.assert_link_status_code_is_not_404(link)
# 断言链接的状态码不是 404。self.assert_no_404_errors(multithreaded=True, timeout=None)
# 断言页面中没有 404 错误。
# 其他命名方式: self.assert_no_broken_links(multithreaded=True, timeout=None)self.print_unique_links_with_status_codes()
# 打印页面中唯一链接的状态码。self.get_pdf_text(pdf, page=None, maxpages=None, password=None,codec='utf-8', wrap=False, nav=False, override=False, caching=True)
# 获取 PDF 文本。self.assert_pdf_text(pdf, text, page=None, maxpages=None, password=None,codec='utf-8', wrap=True, nav=False, override=False, caching=True)
# 断言 PDF 文本。self.create_folder(folder)
# 创建文件夹。self.choose_file(selector, file_path, by="css selector", timeout=None)
# 选择文件上传。self.save_element_as_image_file(selector, file_name, folder=None, overlay_text="")
# 保存元素为图像文件。self.download_file(file_url, destination_folder=None)
# 下载文件。self.save_file_as(file_url, new_file_name, destination_folder=None)
# 保存文件为指定名称。self.save_data_as(data, file_name, destination_folder=None)
# 保存数据为文件。self.append_data_to_file(data, file_name, destination_folder=None)
# 附加数据到文件。self.get_file_data(file_name, folder=None)
# 获取文件数据。self.get_downloads_folder()
# 获取下载文件夹路径。self.get_browser_downloads_folder()
# 获取浏览器下载文件夹路径。self.get_downloaded_files(regex=None, browser=False)
# 获取下载的文件。self.get_path_of_downloaded_file(file, browser=False)
# 获取下载文件的路径。self.get_data_from_downloaded_file(file, timeout=None, browser=False)
# 获取下载文件的数据。self.is_downloaded_file_present(file, browser=False)
# 检查下载的文件是否存在。self.is_downloaded_file_regex_present(regex, browser=False)
# 检查下载的文件是否匹配正则表达式。self.delete_downloaded_file_if_present(file, browser=False)
# 如果存在则删除下载的文件。
# 其他命名方式: self.delete_downloaded_file(file, browser=False)self.assert_downloaded_file(file, timeout=None, browser=False)
# 断言下载的文件存在。self.assert_downloaded_file_regex(regex, timeout=None, browser=False)
# 断言下载的文件匹配正则表达式。self.assert_data_in_downloaded_file(data, file, timeout=None, browser=False)
# 断言下载的文件包含指定数据。self.assert_true(expr, msg=None)
# 断言表达式为真。self.assert_false(expr, msg=None)
# 断言表达式为假。self.assert_equal(first, second, msg=None)
# 断言两个值相等。self.assert_not_equal(first, second, msg=None)
# 断言两个值不相等。self.assert_in(first, second, msg=None)
# 断言第一个值在第二个值中。self.assert_not_in(first, second, msg=None)
# 断言第一个值不在第二个值中。self.assert_raises(*args, **kwargs)
# 断言引发指定的异常。self.wait_for_attribute(selector, attribute, value=None, by="css selector", timeout=None)
# 等待元素的属性值。self.assert_attribute(selector, attribute, value=None, by="css selector", timeout=None)
# 断言元素的属性值。self.assert_title(title)
# 断言页面标题。self.assert_title_contains(substring)
# 断言页面标题包含指定子字符串。self.assert_url(url)
# 断言页面 URL。self.assert_url_contains(substring)
# 断言页面 URL 包含指定子字符串。self.assert_no_js_errors(exclude=[])
# 断言页面中没有 JavaScript 错误。self.inspect_html()
# 检查页面 HTML。self.is_valid_url(url)
# 检查 URL 是否有效。self.is_online()
# 检查是否联网。self.is_chromium()
# 检查是否是 Chromium 浏览器。self.get_chrome_version()
# 获取 Chrome 浏览器版本。self.get_chromium_version()
# 获取 Chromium 浏览器版本。self.get_chromedriver_version()
# 获取 ChromeDriver 版本。self.get_chromium_driver_version()
# 获取 ChromiumDriver 版本。self.get_mfa_code(totp_key=None)
# 获取多因素认证代码。
# 其他命名方式: self.get_totp_code(totp_key=None), self.get_google_auth_password(totp_key=None), self.get_google_auth_code(totp_key=None)self.enter_mfa_code(selector, totp_key=None, by="css selector", timeout=None)
# 输入多因素认证代码。
# 其他命名方式: self.enter_totp_code(selector, totp_key=None, by="css selector", timeout=None)self.convert_css_to_xpath(css)
# 将 CSS 选择器转换为 XPath。self.convert_xpath_to_css(xpath)
# 将 XPath 转换为 CSS 选择器。self.convert_to_css_selector(selector, by)
# 转换为 CSS 选择器。self.set_value(selector, text, by="css selector", timeout=None, scroll=True)
# 设置元素的值。self.js_update_text(selector, text, by="css selector", timeout=None)
# 使用 JavaScript 更新元素的文本。
# 其他命名方式: self.js_type(selector, text, by="css selector", timeout=None), self.set_text(selector, text, by="css selector", timeout=None)self.set_text_content(selector, text, by="css selector", timeout=None, scroll=False)
# 设置元素的文本内容。self.jquery_update_text(selector, text, by="css selector", timeout=None)
# 使用 jQuery 更新元素的文本。
# 其他命名方式: self.jquery_type(selector, text, by="css selector", timeout=None)self.get_value(selector, by="css selector", timeout=None)
# 获取元素的值。self.set_time_limit(time_limit)
# 设置时间限制。self.set_default_timeout(timeout)
# 设置默认超时时间。self.reset_default_timeout()
# 重置默认超时时间。self.fail(msg=None)
# 标记测试失败。self.skip(reason="")
# 跳过测试。self.start_recording_console_logs()
# 开始记录控制台日志。self.console_log_string(string)
# 记录控制台日志字符串。self.console_log_script(script)
# 记录控制台日志脚本。self.get_recorded_console_logs()
# 获取记录的控制台日志。self.set_local_storage_item(key, value)
# 设置本地存储项。self.get_local_storage_item(key)
# 获取本地存储项。self.remove_local_storage_item(key)
# 移除本地存储项。self.clear_local_storage()
# 清除本地存储。
# 其他命名方式: delete_local_storage()self.get_local_storage_keys()
# 获取本地存储的键。self.get_local_storage_items()
# 获取本地存储的所有项。self.set_session_storage_item(key, value)
# 设置会话存储项。self.get_session_storage_item(key)
# 获取会话存储项。self.remove_session_storage_item(key)
# 移除会话存储项。self.clear_session_storage()
# 清除会话存储。
# 其他命名方式: delete_session_storage()self.get_session_storage_keys()
# 获取会话存储的键。self.get_session_storage_items()
# 获取会话存储的所有项。self.set_wire_proxy(string)
# 设置代理,要求使用 "--wire"。self.add_css_link(css_link)
# 添加 CSS 链接。self.add_js_link(js_link)
# 添加 JavaScript 链接。self.add_css_style(css_style)
# 添加 CSS 样式。self.add_js_code_from_link(js_link)
# 从链接添加 JavaScript 代码。self.add_js_code(js_code)
# 添加 JavaScript 代码。self.add_meta_tag(http_equiv=None, content=None)
# 添加 meta 标签。self.create_presentation(name=None, theme="default", transition="default")
# 创建演示文稿。self.add_slide(content=None, image=None, code=None, iframe=None,content2=None, notes=None, transition=None, name=None)
# 添加幻灯片。self.save_presentation(name=None, filename=None, show_notes=False, interval=0)
# 保存演示文稿。self.begin_presentation(name=None, filename=None, show_notes=False, interval=0)
# 开始演示文稿。self.create_pie_chart(chart_name=None, title=None, subtitle=None,data_name=None, unit=None, libs=True,labels=True, legend=True)
# 创建饼图。self.create_bar_chart(chart_name=None, title=None, subtitle=None,data_name=None, unit=None, libs=True,labels=True, legend=True)
# 创建柱状图。self.create_column_chart(chart_name=None, title=None, subtitle=None,data_name=None, unit=None, libs=True,labels=True, legend=True)
# 创建柱形图。self.create_line_chart(chart_name=None, title=None, subtitle=None,data_name=None, unit=None, zero=False, libs=True,labels=True, legend=True)
# 创建折线图。self.create_area_chart(chart_name=None, title=None, subtitle=None,data_name=None, unit=None, zero=False, libs=True,labels=True, legend=True)
# 创建面积图。self.add_series_to_chart(data_name=None, chart_name=None)
# 添加数据系列到图表。self.add_data_point(label, value, color=None, chart_name=None)
# 添加数据点到图表。self.save_chart(chart_name=None, filename=None, folder=None)
# 保存图表。self.display_chart(chart_name=None, filename=None, interval=0)
# 显示图表。self.extract_chart(chart_name=None)
# 提取图表。self.create_tour(name=None, theme=None)
# 创建导览。self.create_shepherd_tour(name=None, theme=None)
# 创建 Shepherd 导览。self.create_bootstrap_tour(name=None)
# 创建 Bootstrap 导览。self.create_hopscotch_tour(name=None)
# 创建 Hopscotch 导览。self.create_introjs_tour(name=None)
# 创建 Intro.js 导览。self.set_introjs_colors(theme_color=None, hover_color=None)
# 设置 Intro.js 导览颜色。self.add_tour_step(message, selector=None, name=None, title=None, theme=None, alignment=None)
# 添加导览步骤。self.play_tour(name=None, interval=0)
# 播放导览。
# 其他命名方式: self.start_tour(name=None, interval=0)self.export_tour(name=None, filename="my_tour.js", url=None)
# 导出导览。self.activate_jquery_confirm()
# 启用 jQuery Confirm。self.set_jqc_theme(theme, color=None, width=None)
# 设置 jQuery Confirm 主题。self.reset_jqc_theme()
# 重置 jQuery Confirm 主题。self.get_jqc_button_input(message, buttons, options=None)
# 获取 jQuery Confirm 按钮输入。self.get_jqc_text_input(message, button=None, options=None)
# 获取 jQuery Confirm 文本输入。self.get_jqc_form_inputs(message, buttons, options=None)
# 获取 jQuery Confirm 表单输入。self.activate_messenger()
# 启用 Messenger。self.post_message(message, duration=None, pause=True, style="info")
# 发送信息。self.post_message_and_highlight(message, selector, by="css selector")
# 发送信息并高亮元素。self.post_success_message(message, duration=None, pause=True)
# 发送成功信息。self.post_error_message(message, duration=None, pause=True)
# 发送错误信息。self.set_messenger_theme(theme="default", location="default", max_messages="default")
# 设置 Messenger 主题。self.generate_referral(start_page, destination_page, selector=None)
# 生成推荐。self.generate_traffic(start_page, destination_page, loops=1, selector=None)
# 生成流量。self.generate_referral_chain(pages)
# 生成推荐链。self.generate_traffic_chain(pages, loops=1)
# 生成流量链。self.get_element(selector, by="css selector", timeout=None)
# 获取指定的元素。
# 其他命名方式: self.wait_for_selector(selector, by="css selector", timeout=None), self.locator(selector, by="css selector", timeout=None), self.wait_for_element_present(selector, by="css selector", timeout=None)self.wait_for_query_selector(selector, by="css selector", timeout=None)
# 等待指定的查询选择器。self.assert_element_present(selector, by="css selector", timeout=None)
# 断言元素存在。self.assert_elements_present(*args, **kwargs)
# 断言多个元素存在。self.find_element(selector, by="css selector", timeout=None)
# 查找指定的元素。
# 其他命名方式: self.wait_for_element(selector, by="css selector", timeout=None), self.wait_for_element_visible(selector, by="css selector", timeout=None)self.assert_element(selector, by="css selector", timeout=None)
# 断言指定的元素。
# 其他命名方式: self.assert_element_visible(selector, by="css selector", timeout=None)self.assert_elements(*args, **kwargs)
# 断言多个元素。
# 其他命名方式: self.assert_elements_visible(*args, **kwargs)self.find_text(text, selector="html", by="css selector", timeout=None)
# 查找指定文本。
# 其他命名方式: self.wait_for_text(text, selector="html", by="css selector", timeout=None), self.wait_for_text_visible(text, selector="html", by="css selector", timeout=None)self.find_exact_text(text, selector="html", by="css selector", timeout=None)
# 查找精确文本。
# 其他命名方式: self.wait_for_exact_text(text, selector="html", by="css selector", timeout=None), self.wait_for_exact_text_visible(text, selector="html", by="css selector", timeout=None)self.find_non_empty_text(selector="html", by="css selector", timeout=None)
# 查找非空文本。
# 其他命名方式: self.wait_for_non_empty_text(selector="html", by="css selector", timeout=None), self.wait_for_non_empty_text_visible(selector="html", by="css selector", timeout=None)self.assert_text(text, selector="html", by="css selector", timeout=None)
# 断言文本。
# 其他命名方式: self.assert_text_visible(text, selector="html", by="css selector", timeout=None)self.assert_exact_text(text, selector="html", by="css selector", timeout=None)
# 断言精确文本。self.wait_for_link_text_present(link_text, timeout=None)
# 等待链接文本出现。self.wait_for_partial_link_text_present(link_text, timeout=None)
# 等待部分链接文本出现。self.find_link_text(link_text, timeout=None)
# 查找链接文本。
# 其他命名方式: self.wait_for_link_text(link_text, timeout=None), self.wait_for_link_text_visible(link_text, timeout=None)self.assert_link_text(link_text, timeout=None)
# 断言链接文本。
# 其他命名方式: self.assert_link(link_text, timeout=None)self.find_partial_link_text(partial_link_text, timeout=None)
# 查找部分链接文本。
# 其他命名方式: self.wait_for_partial_link_text(partial_link_text, timeout=None)self.assert_partial_link_text(partial_link_text, timeout=None)
# 断言部分链接文本。self.wait_for_element_absent(selector, by="css selector", timeout=None)
# 等待元素消失。
# 其他命名方式: self.wait_for_element_not_present(selector, by="css selector", timeout=None)self.assert_element_absent(selector, by="css selector", timeout=None)
# 断言元素消失。
# 其他命名方式: self.assert_element_not_present(selector, by="css selector", timeout=None)self.wait_for_element_clickable(selector, by="css selector", timeout=None)
# 等待元素可点击。self.wait_for_element_not_visible(selector, by="css selector", timeout=None)
# 等待元素不可见。self.assert_element_not_visible(selector, by="css selector", timeout=None)
# 断言元素不可见。self.wait_for_text_not_visible(text, selector="html", by="css selector", timeout=None)
# 等待文本不可见。self.wait_for_exact_text_not_visible(text, selector="html", by="css selector", timeout=None)
# 等待精确文本不可见。self.assert_text_not_visible(text, selector="html", by="css selector", timeout=None)
# 断言文本不可见。self.assert_exact_text_not_visible(text, selector="html", by="css selector", timeout=None)
# 断言精确文本不可见。self.assert_non_empty_text(selector="html", by="css selector", timeout=None)
# 断言非空文本。self.wait_for_attribute_not_present(selector, attribute, value=None, by="css selector", timeout=None)
# 等待属性不存在。self.assert_attribute_not_present(selector, attribute, value=None, by="css selector", timeout=None)
# 断言属性不存在。self.accept_alert(timeout=None)
# 接受警报。
# 其他命名方式: self.wait_for_and_accept_alert(timeout=None)self.dismiss_alert(timeout=None)
# 解散警报。
# 其他命名方式: self.wait_for_and_dismiss_alert(timeout=None)self.switch_to_alert(timeout=None)
# 切换到警报。
# 其他命名方式: self.wait_for_and_switch_to_alert(timeout=None)self.quit_extra_driver(driver=None)
# 退出额外的 WebDriver 实例。self.check_window(name="default", level=0, baseline=False, check_domain=True, full_diff=False)
# 检查窗口状态。self.deferred_assert_element(selector, by="css selector", timeout=None, fs=False)
# 延迟断言元素。
# 其他命名方式: self.delayed_assert_element(selector, by="css selector", timeout=None, fs=False)self.deferred_assert_element_present(selector, by="css selector", timeout=None, fs=False)
# 延迟断言元素存在。
# 其他命名方式: self.delayed_assert_element_present(selector, by="css selector", timeout=None, fs=False)self.deferred_assert_text(text, selector="html", by="css selector", timeout=None, fs=False)
# 延迟断言文本。
# 其他命名方式: self.delayed_assert_text(text, selector="html", by="css selector", timeout=None, fs=False)self.deferred_assert_exact_text(text, selector="html", by="css selector", timeout=None, fs=False)
# 延迟断言精确文本。
# 其他命名方式: self.delayed_assert_exact_text(text, selector="html", by="css selector", timeout=None, fs=False)self.deferred_assert_non_empty_text(selector="html", by="css selector", timeout=None, fs=False)
# 延迟断言非空文本。
# 其他命名方式: self.delayed_assert_non_empty_text(selector="html", by="css selector", timeout=None, fs=False)self.deferred_check_window(name="default", level=0, baseline=False, check_domain=True, full_diff=False, fs=False)
# 延迟检查窗口状态。
# 其他命名方式: self.delayed_check_window(name="default", level=0, baseline=False, check_domain=True, full_diff=False, fs=False)self.process_deferred_asserts(print_only=False)
# 处理延迟断言。
# 其他命名方式: self.process_delayed_asserts(print_only=False)self.fail(msg=None)
# 标记测试失败。self._check_browser()
# 检查浏览器状态。self._print(TEXT)
# 打印文本。

        使用示例:

driver.default_get(url)
# 使用默认方式获取 URL。driver.open(url)
# 打开指定的 URL。driver.click(selector)
# 点击指定的元素。driver.click_link(link_text)
# 点击指定的链接文本。driver.click_if_visible(selector)
# 如果元素可见则点击。driver.click_active_element()
# 点击当前活动元素。driver.send_keys(selector, text)
# 向指定的元素发送键盘输入。driver.press_keys(selector, text)
# 向指定的元素发送键盘按键。driver.type(selector, text)
# 在指定的元素中输入文本。driver.submit(selector)
# 提交指定的表单。driver.assert_element(selector)
# 断言指定的元素。driver.assert_element_present(selector)
# 断言元素存在。driver.assert_element_not_visible(selector)
# 断言元素不可见。driver.assert_text(text, selector)
# 断言文本。driver.assert_exact_text(text, selector)
# 断言精确文本。driver.find_element(selector)
# 查找指定的元素。driver.find_elements(selector)
# 查找所有匹配的元素。driver.wait_for_element(selector)
# 等待指定的元素。driver.wait_for_element_visible(selector)
# 等待元素可见。driver.wait_for_element_present(selector)
# 等待元素存在。driver.wait_for_selector(selector)
# 等待选择器。driver.wait_for_text(text, selector)
# 等待文本。driver.wait_for_exact_text(text, selector)
# 等待精确文本。driver.wait_for_and_accept_alert()
# 等待并接受警报。driver.wait_for_and_dismiss_alert()
# 等待并解散警报。driver.is_element_present(selector)
# 检查元素是否存在。driver.is_element_visible(selector)
# 检查元素是否可见。driver.is_text_visible(text, selector)
# 检查文本是否可见。driver.is_exact_text_visible(text, selector)
# 检查精确文本是否可见。driver.is_attribute_present(selector, attribute)
# 检查属性是否存在。driver.get_text(selector)
# 获取元素的文本内容。driver.js_click(selector)
# 使用 JavaScript 点击元素。driver.get_active_element_css()
# 获取当前活动元素的 CSS。driver.get_locale_code()
# 获取语言区域代码。driver.get_origin()
# 获取原始 URL。driver.get_user_agent()
# 获取用户代理字符串。driver.highlight(selector)
# 高亮指定的元素。driver.highlight_click(selector)
# 高亮并点击指定的元素。driver.highlight_if_visible(selector)
# 如果元素可见则高亮。driver.sleep(seconds)
# 暂停指定的秒数。driver.locator(selector)
# 获取选择器。driver.get_attribute(selector, attribute)
# 获取元素的属性值。driver.get_page_source()
# 获取页面源代码。driver.get_title()
# 获取页面标题。driver.switch_to_frame(frame="iframe")
# 切换到指定的 iframe。driver.get(url)
# 获取指定的 URL。driver.uc_open(url)
# 在 undetected-chromedriver 模式下打开 URL。driver.uc_open_with_tab(url)
# 在新标签页中打开 URL。driver.uc_open_with_reconnect(url, reconnect_time=None)
# 打开 URL 并重新连接。driver.uc_open_with_disconnect(url, timeout=None)
# 打开 URL 并断开连接。driver.reconnect(timeout)
# 重新连接。driver.disconnect()
# 断开连接。driver.connect()
# 连接。driver.uc_click(selector)
# 使用 undetected-chromedriver 点击元素。driver.uc_gui_press_key(key)
# 使用 PyAutoGUI 按下键盘键。driver.uc_gui_press_keys(keys)
# 使用 PyAutoGUI 按下键盘键列表。driver.uc_gui_write(text)
# 使用 PyAutoGUI 输入文本。driver.uc_gui_click_x_y(x, y, timeframe=0.25)
# 使用 PyAutoGUI 点击屏幕上的指定位置。driver.uc_gui_click_cf(frame="iframe", retry=False, blind=False)
# 使用 PyAutoGUI 点击 CF Turnstile。driver.uc_gui_handle_cf(frame="iframe")
# 使用 PyAutoGUI 处理 CF Turnstile。driver.uc_switch_to_frame(frame="iframe")
# 使用 undetected-chromedriver 切换到指定的 iframe。

最后的话

        我在写一个基于selenium和seleniumbase的浏览器控制的库,以便在需要使用selenium时候能够快速开始,而不需要每次都重复造轮子。欢迎提PR。

        虽然seleniumbase实际上是一个已经封装过了的库,但其功能非常强大,以至于可能我并不需要这么多功能(我是在找隐藏指纹时候找到这个的,因为原始的uc库忽然用不了了)。更多的,我可能需要的是多个工具或者兼容性的适配。所以,有必要另外再自己写一个。

GitHub - songxf1024/selenium_browser: A generic library to control the browser based on selenium.A generic library to control the browser based on selenium. - songxf1024/selenium_browsericon-default.png?t=N7T8https://github.com/songxf1024/selenium_browser

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

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

相关文章

算法库应用--KMP算法解决串匹配问题

学习来源 学习贺利坚老师博客 数据结构例程——串的模式匹配(KMP算法)_数据结构模式匹配例题-CSDN博客 本人引导博客 串的匹配 (KPM算法由来引导)_kpm匹配失败-CSDN博客 转载大佬sofu博客 https://www.cnblogs.com/dusf/p/kmp.html 本人详细思路引导b战…

代码随想录算法训练营第四十九天| 300.最长递增子序列 , 674. 最长连续递增序列 , 718. 最长重复子数组

300. 最长递增子序列 - 力扣&#xff08;LeetCode&#xff09; class Solution {public int lengthOfLIS(int[] nums) {int[] dp new int[nums.length];dp[0] 1;for(int i1;i<nums.length;i){for(int j0;j<i;j){if(nums[i] > nums[j]){dp[i] Math.max(dp[j],dp[i])…

【Spring Boot】关系映射开发(三):多对多映射

《JPA 从入门到精通》系列包含以下文章&#xff1a; Java 持久层 API&#xff1a;JPA认识 JPA 的接口JPA 的查询方式基于 JPA 开发的文章管理系统&#xff08;CRUD&#xff09;关系映射开发&#xff08;一&#xff09;&#xff1a;一对一映射关系映射开发&#xff08;二&#…

香橙派AIpro做目标检测

使用香橙派AIpro做目标检测 文章目录 使用香橙派AIpro做目标检测香橙派AIpro开发板介绍香橙派AIpro应用体验快速体验香橙派的AI功能YOLOV5s目标检测使用场景描述图像目标检测视频目标检测摄像头目标检测YOLOv5s 目标检测的运行结果分析香橙派 AIpro 在运行过程中的表现 香橙派A…

git杂记

git 安装&#xff1a; 在 Windows 上安装 Git 也有几种安装方法。 官方版本可以在 Git 官方网站下载。 打开 https://git-scm.com/download/win&#xff0c;下载会自动开始。 要注意这是一个名为 Git for Windows 的项目&#xff08;也叫做 msysGit&#xff09;&#xff0c;和…

基于Java+SpringMvc+Vue技术的实验室管理系统设计与实现

博主介绍&#xff1a;硕士研究生&#xff0c;专注于信息化技术领域开发与管理&#xff0c;会使用java、标准c/c等开发语言&#xff0c;以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年&#xff0c;拥有近12年的管理工作经验&#xff0c;拥有较丰富的技术架…

SUSAN

1995年英国牛津大学的S.M.Smith提出了一种新的图像边缘检测算法SUSAN算法,不同于以前经典边缘检测算法,SUSAN算法基于灰度相似性比较,采用圆形模板,对图像进行灰度差统计,无需计算方向导数,而且具备积分特性,它简单而且有效,适用于图像中边缘和角点的检测,可以去除图像…

土豆炒肉做法

菜单&#xff1a;土豆、葱、铁辣子、纯瘦肉、淀粉、生抽、酱油、刀、案板、十三香、盐巴、擦板 流程&#xff1a; 洗土豆&#xff0c;削皮&#xff0c;擦成条&#xff0c;用凉水过滤两遍淀粉&#xff0c;顺便放个燥里洗肉&#xff0c;切成条&#xff0c;按照生抽、酱油、淀粉、…

js好用的动态分页插件

js好用的动态分页插件是一款简单的分页样式插件&#xff0c;支持样式类型&#xff0c;当前页&#xff0c;每页显示数量&#xff0c;按钮数量&#xff0c;总条数&#xff0c;上一页文字&#xff0c;下一页文字&#xff0c;输入框跳转等功能。 js好用的动态分页插件

通过IDEA生成webapp及web.xml配置文件

1、选择File->Project Structure 2、选择Modules-> + -> Web 有的springboot工程选择是war工程,这个web可能已经存在了。 如果不存在,就手动创建,创建后,需要修改pom.xml中的配置 <packaging>war</packaging> 3、创建webapp根目录 这步重点就是创建…

介绍一款Java开发的商业开源MES系统

介绍一款Java开发的开源MES系统&#xff0c;万界星空科技开源的MES系统。该系统基于Java开发&#xff0c;具有广泛的适用性和高度的可定制性&#xff0c;能够满足不同行业、不同规模企业的智能制造需求。 一、系统概述 万界星空科技开源的MES系统是一款面向制造企业车间执行层…

昇思25天学习打卡营第19天 | CycleGAN图像风格迁移互换

内容介绍&#xff1a; CycleGAN(Cycle Generative Adversarial Network) 即循环对抗生成网络&#xff0c;该模型实现了一种在没有配对示例的情况下学习将图像从源域 X 转换到目标域 Y 的方法。 该模型一个重要应用领域是域迁移(Domain Adaptation)&#xff0c;可以通俗地理解…

Java中获取Class对象的三种方式

Java中获取Class对象的三种方式 1、对象调用getClass()方法2、类名.class的方式3、通过Class.forName()静态方法4、总结 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在Java中&#xff0c;Class对象是一个非常重要的概念&#xff0c;它代…

JVM原理(二十):JVM虚拟机内存的三特性详解

1. 原子性、可进行、有序性 1.1. 原子性 Java内存模型围绕着在并发过程中如何处理原子性、可见性和有序性这三个特征来建立的。 Java内存模型来直接保证的原子性变量操作包括read、load、assign、use、store和write这六个。我们大致可以认为&#xff0c;基本数据类型的访问、…

科普新能源充电桩

充电桩是新能源电动车的配套基础设施&#xff0c;为电动车提供充电服务&#xff0c;与我们的生活也是息息相关&#xff0c;本篇文章来科普一下充电桩基础知识。 充电桩的分类 按照供电方式分类 交流充电桩&#xff1a;特点是小电流、桩体较小、安装灵活&#xff1b;直流充电…

【TB作品】51单片机 Proteus仿真 超声波LCD1602ADC0832 身高体重测量仪

00024 超声波LCD1602ADC0832 实验报告&#xff1a;基于51单片机的身高体重测量仪设计 背景介绍 本实验设计并实现了一个基于51单片机的身高体重测量仪。该系统利用超声波传感器测量高度&#xff0c;通过ADC0832模数转换芯片获取重量数据&#xff0c;并使用LCD1602显示屏显示…

Alt与Tab切换窗口时将Edge多个标签页作为一个整体参与切换的方法

本文介绍在Windows电脑中&#xff0c;使用Alt与Tab切换窗口时&#xff0c;将Edge浏览器作为一个整体参与切换&#xff0c;而不是其中若干个页面参与切换的方法。 最近&#xff0c;需要将主要使用的浏览器由原本的Chrome换为Edge&#xff1b;但是&#xff0c;在更换后发现&#…

桌面快充插线板+伸缩数据线,轻松实现1+1>2

手机、平板、笔记本等电子设备已成为我们日常工作和学习的必备工具。然而,随着设备数量的增加,充电问题也日益凸显。桌面空间有限,多个快充头不仅显得杂乱无章,而且效率低下,无法满足我们高效办公的需求。 在这样的背景下,倍思Nomos氮化镓100W桌面充电站凭借其创新的设计和强大…

SpringBoot新手快速入门系列教程七:基于一个低配centoos服务器,如何通过宝塔面板部署一个SpringBoot项目

1&#xff0c;如何打包一个项目 通过IDEA自带的命令行&#xff0c;执行 ./gradlew clean build 2&#xff0c;检查生成的JAR文件 进入 build/libs 目录&#xff0c;你应该会看到一个类似 helloredis-0.0.1-SNAPSHOT.jar 的文件。 3&#xff1a;运行生成的JAR文件 你可以在…