Windows自动化2️⃣元素定位分析+图片视频上传等

windows自动化,难点元素定位
XPath轴(XPath Axes)可定义某个相对于当前节点的节点集:

  1. preceding-sibling 选取当前节点之前的所有同级节点
  2. following-sibling 选取当前节点之后的所有同级节点
  3. preceding 选取文档中当前节点的开始标签之前的所有节点
  4. following 选取文档中当前节点的结束标签之后的所有节点
  5. preceding-sibling,选取当前节点之前的所有同级节点,同一个parent下该节点之前的节点,即"哥哥"节点(是同父的哥哥节点)。
  6. /AAA/XXX/preceding-sibling:😗 /AAA/XXX节点的所有之前同级节, * 可以是div, span等

以上常用, 其实** 关键还是基于Name属性进行相对定位! **

取不出来具体某一个, 可以全部取出, 然后通过python进行锁定, 继而进行后续操作 !

代码分享:

python 复制代码
Texts = self.driver.find_elements(by=By.XPATH, value='//Group/preceding-sibling::Text')
Texts[-1].click()
time.sleep(1)
self.driver.find_element(by=By.XPATH, value='//Group/Text[@Name="xxx"]').click()
self.driver.find_element(by=By.XPATH, value='//Group/Button[@Name="确定"]').click()
# 等1秒, 判断个人名片可见
time.sleep(1)
assert self.driver.find_element(by=By.XPATH, value='//Document[@Name="hwork-desktop-im"]/Text[@Name="个人名片"]').is_displayed()

对于, 属性为, IsKeyboardFocusable False 无法直接进行操作的, 可以结合其他自动化工具, 进行!

下面我用的pyautogui,去点击的, 因为 这个元素当前无法直接通过这种定位方式进行点击

python 复制代码
stat = self.driver.find_elements(by=By.XPATH, value="//Group/preceding-sibling::Text")
# 选择表情
stat[-7].click()
# 找到 第一个图标
image = self.driver.find_element(by=By.XPATH,
                                 value='//Document[@Name="hwork-desktop-im"]/List/ListItem/Image')
# 鼠标悬停在图标上方
ActionChains(self.driver).move_to_element(image).perform()
# 按下鼠标左键
pyautogui.mouseDown(button='left')
pyautogui.sleep(1)
# 释放鼠标
pyautogui.mouseUp(button='left')
time.sleep(1)
# 点击发送
self.driver.find_element(By.XPATH, '//Document[@Name="hwork-desktop-im"]/Button[@Name="发送"]').click()

一些共用方法,分享

python 复制代码
# 切换为英文输入法
def shift_en(element):

    flag = True
    while flag:
        user32 = ctypes.WinDLL('user32', use_last_error=True)
        curr_window = user32.GetForegroundWindow()
        thread_id = user32.GetWindowThreadProcessId(curr_window, 0)
        klid = user32.GetKeyboardLayout(thread_id)
        lid = klid & (2 ** 16 - 1)
        lid_hex = hex(lid)
        # print(lid_hex)
        if lid_hex == '0x409':
            # print('当前的输入法状态是英文输入模式\n')
            flag = False
        elif lid_hex == '0x804':
            # print('当前的输入法是中文输入模式\n')
            element.send_keys(Keys.META, Keys.SPACE)
            # print('建议删除多余输入法,只保留两种输入法\n')
        else:
            element.send_keys(Keys.META, Keys.SPACE)
            print('当前的输入法既不是英文输入也不是中文输入\n建议删除多余输入法,只保留两种输入法')
        time.sleep(1)
python 复制代码
# 图片,视频路径
def get_filepath():
    # 当前目录
    # baseDir = os.path.dirname(os.path.abspath(os.path.relpath(sys.argv[0])))
    # 上级目录
    baseDir2 = Path(os.path.relpath(sys.argv[0])).resolve().parent.parent
    # print(baseDir2)
    return str(baseDir2) + "\\file\\"
python 复制代码
import win32con
import win32clipboard as wincld
# 给鼠标右键复制使用
def ctrl_c(info):
    wincld.OpenClipboard()
    wincld.EmptyClipboard()
    wincld.SetClipboardData(win32con.CF_UNICODETEXT, info)
    wincld.CloseClipboard()
python 复制代码
# 图片/视频上传
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
def upload_file(driver, file):
    # 定位文件路径输入框并输入文件路径
    file_input = WebDriverWait(driver, 60, 0.5).until(EC.visibility_of_element_located((By.XPATH, "//Edit[@Name='文件名(N):']")))
    file_input.send_keys(file)
    # 定位打开按钮并点击
    file_open_btn = WebDriverWait(driver, 60, 0.5).until(EC.visibility_of_element_located((By.XPATH, "//Button[@Name='打开(O)']")))
    file_open_btn.click()
相关推荐
弗锐土豆2 小时前
Windows系统中Oracle VM VirtualBox的安装
windows·虚拟机·virtualbox
秋の花2 小时前
【JAVA基础】Java集合基础
java·开发语言·windows
Jason-河山3 小时前
【自动化更新,让商品信息跳舞】——利用API返回值的幽默编程之旅
运维·自动化
海阔天空_20134 小时前
Python pyautogui库:自动化操作的强大工具
运维·开发语言·python·青少年编程·自动化
桥田智能4 小时前
气爪在自动化装配线中是如何应用的?
运维·自动化
零意@5 小时前
ubuntu切换不同版本的python
windows·python·ubuntu
Tassel_YUE6 小时前
网络自动化04:python实现ACL匹配信息(主机与主机信息)
网络·python·自动化
写bug的小屁孩6 小时前
前后端交互接口(三)
运维·服务器·数据库·windows·用户界面·qt6.3
hairenjing11238 小时前
在 Android 手机上从SD 卡恢复数据的 6 个有效应用程序
android·人工智能·windows·macos·智能手机
plmm烟酒僧11 小时前
Windows下QT调用MinGW编译的OpenCV
开发语言·windows·qt·opencv