Введение в автоматизированное тестирование ПК — pywinauto Часть 1: Первое введение
Введение в автоматизированное тестирование ПК — pywinauto Часть 1: Первое введение

Предисловие

  • существуют Сфера разработки программного обеспечения,Автоматизированное Обучение — важная практика, которая может повысить эффективность тестирования, снизить трудозатраты и обеспечить качество программного обеспечения. ПК Автоматизированное обучение конкретно относится к Windows приложение для платформы Автоматизированное тестирование,и pywinauto это инструмент, используемый для реализации Windows GUI Приложение Автоматизированное тестированиеиз Python библиотека. Эта статья познакомит вас PC Автоматизированное Основная концепция обучения、Обычно Используемые инструменты и первое знакомство pywinauto и демонстрирует его базовое использование на примере работы с Блокнотом.

Что такое автоматизированное тестирование на ПК?

  • PC Автоматизированное Обучение относится к использованию автоматизированных инструментов или сценариев для моделирования действий пользователя. Windows Приложение платформы проходит функциональное тестирование, тестирование производительности и т. д., чтобы убедиться, что оно работает должным образом. По сравнению с ручным тестированием, Автоматизированное Изменения могут повысить эффективность тестирования, снизить затраты на тестирование и могут быть реализованы в процессах непрерывной интеграции и непрерывной доставки. тестирование。

Распространенные инструменты автоматизированного тестирования ПК

  • существовать PC Автоматизированное поле новостей, их много Обычно Используемый инструмент:
Язык кода:txt
копировать
- Селен: используется для Web Применение Автоматизированное тестирование。
- pywinauto: используется для Windows GUI Применение Автоматизированное тестирование。
- AutoIt: используется для Windows платформа Автоматизированное Кстати, поддерживает имитацию операций с клавиатурой и мышью.

Что такое pywinauto?

  • pywinauto это продукт, основанный на Python Библиотека с открытым исходным кодом для Автоматизированного тестирование Windows платформа GUI приложение. Он может имитировать операции пользователя с клавиатурой и мышью, а также получать и изменять свойства управления приложения. pywinauto Обеспечивает простой, но мощный API, который позволяет разработчикам легко писать Автоматизированное тестирование Скрипт。

Список поддерживаемых технологий специальных возможностей в Windows

  • После установки pywinauto первое, что необходимо — это определить, какую технологию специальных возможностей (бэкэнд pywinauto) может использовать ваше приложение. Обычно используемые из них включают Win32 API и MS UI.
  • Если вы не знаете, для какой технологии специальных возможностей подходит программа, вы можете использовать для этого инструменты проверки объектов с графическим интерфейсом. К наиболее часто используемым инструментам проверки относятся Inspect.exe, Spy++ и т. д. В качестве примера используется Inspect.exe:

Операция «Блокнот» автоматически записывает

  • Окружающая среда: победа 10, Python 3.12.
Язык кода:Python
копировать
from pywinauto import Application

# соединять PC Два способа подачи заявления
# app = Application(backend="uia").start("notepad.exe")
app = Application(backend="uia").connect(process=32120)

print(app.process)

# Получить главное окно
top_window = app.window(title="Нет заголовка - Notepad", control_type="Window")
# Древовидная структура меню управления печатью
top_window.print_control_identifiers()

# Получить поле ввода
document = top_window.child_window(control_type="Document")

document.print_control_identifiers()
# Отметьте, правильно ли выбрано поле ввода
document.draw_outline(colour='red')

# писать
document.click_input()
document.type_keys(keys="Your text here", with_spaces=True)
  • Результат вывода:
Язык кода:txt
копировать
32120
Control Identifiers:

Dialog - 'Без названия - Notepad'    (L-1512, T194, R-192, B886)
['Dialog', 'Без названия - NotepadDialog', 'Без названия - Notepad']
child_window(title="Нет заголовка - Notepad", control_type="Window")
   | 
   | Pane - ''    (L-1505, T280, R-199, B879)
   | ['Pane', 'Без названияPane', 'Pane0', 'Pane1', 'Без названияPane0', 'Без названияPane1']
   |    | 
   |    | Document - ''    (L-1505, T280, R-199, B879)
   |    | ['Document', 'Без названияDocument']
   | 
   | Pane - ''    (L-1459, T205, R-1173, B237)
   | ['Pane2', 'Без названияPane2']
   |    | 
   |    | TabControl - ''    (L-18704, T-17045, R-1129, B241)
   |    | ['TabControl', «TabControl добавить новую вкладку»]
   |    | child_window(auto_id="Tabs", control_type="Tab")
   |    |    | 
   |    |    | ListBox - ''    (L-18704, T-17045, R-1169, B241)
   |    |    | ['ListBox']
   |    |    | child_window(auto_id="TabListView", control_type="List")
   |    |    |    | 
   |    |    |    | TabItem - 'Без названия. Не модифицировано. '    (L-1455, T205, R-1173, B241)
   |    |    |    | ['Без названия. Не модифицировано. TabItem', 'Без названия. Не модифицировано. ', 'TabItem']
   |    |    |    | child_window(title="Нет заголовка. Не модифицировано. ", control_type="TabItem")
   |    |    |    |    | 
   |    |    |    |    | Static - 'Без названия'    (L-1440, T214, R-1398, B232)
   |    |    |    |    | ['Static', 'Без названия', 'Без названияStatic']
   |    |    |    |    | child_window(title="Нет заголовка", control_type="Text")
   |    |    |    |    | 
   |    |    |    |    | Button - «Закрыть вкладку»    (L-1219, T209, R-1183, B236)
   |    |    |    |    | ['Button', «Закрыть вкладку», «Кнопка закрытия вкладки», 'Button0', 'Button1']
   |    |    |    |    | child_window(title="Закрыть вкладку", auto_id="CloseButton", control_type="Button")
   |    |    | 
   |    |    | Button - «Добавить новую вкладку»    (L-1166, T210, R-1130, B237)
   |    |    | ['Button2', «Добавить кнопку новой вкладки», «Добавить новую вкладку»]
   |    |    | child_window(title="Добавить новую вкладку", auto_id="AddButton", control_type="Button")
   |    | 
   |    | Pane - «Блокнот автоматически сохраняет прогресс. Весь ваш контент будет доступен при следующем открытии Блокнота. '    (L0, T0, R0, B0)
   |    | ['Блокнот автоматически сохраняет прогресс. Весь ваш контент будет доступен при следующем открытии Блокнота. Пане', «Блокнот автоматически сохраняет прогресс. Весь ваш контент будет доступен при следующем открытии Блокнота. ', 'Pane3']
   |    | child_window(title="Блокнот автоматически сохраняет прогресс. Весь ваш контент будет доступен при следующем открытии Блокнота.", auto_id="TeachingTip", control_type="Pane")
   | 
   | Pane - ''    (L-1505, T242, R-365, B275)
   | ['Pane4', 'Без названияPane3']
   |    | 
   |    | Menu - ''    (L-1505, T242, R-1310, B278)
   |    | ['Menu', 'Без названияMenu', 'Menu0', 'Menu1']
   |    | child_window(auto_id="MenuBar", control_type="MenuBar")
   |    |    | 
   |    |    | MenuItem - 'документ'    (L-1500, T242, R-1444, B278)
   |    |    | ['документ', 'Файл Меню Элемент', 'MenuItem', 'MenuItem0', 'MenuItem1']
   |    |    | child_window(title="файл", auto_id="File", control_type="MenuItem")
   |    |    | 
   |    |    | MenuItem - 'редактировать'    (L-1435, T242, R-1380, B278)
   |    |    | ['редактировать', 'Редактировать Меню Элемент', 'MenuItem2']
   |    |    | child_window(title="Изменить", auto_id="Edit", control_type="MenuItem")
   |    |    | 
   |    |    | MenuItem - 'Проверять'    (L-1370, T242, R-1314, B278)
   |    |    | ['Проверять', 'ViewMenuItem', 'MenuItem3']
   |    |    | child_window(title="Просмотр", auto_id="View", control_type="MenuItem")
   |    | 
   |    | Button - 'настраивать'    (L-237, T243, R-203, B277)
   |    | ['Button3', 'настраивать', 'SetButton']
   |    | child_window(title="Настройки", auto_id="SettingsButton", control_type="Button")
   | 
   | TitleBar - ''    (L0, T0, R0, B0)
   | ['TitleBar']
   |    | 
   |    | Menu - 'система'    (L-1503, T203, R-1478, B228)
   |    | ['Menu2', 'система', 'Системное меню', «Система 0», «Система 1»]
   |    | child_window(title="Система", auto_id="MenuBar", control_type="MenuBar")
   |    |    | 
   |    |    | MenuItem - 'система'    (L-1503, T203, R-1478, B228)
   |    |    | ['MenuItem4', 'Системный Элемент Меню', «Система 2»]
   |    |    | child_window(title="Система", control_type="MenuItem")
   |    | 
   |    | Button - «минимизировать»    (L-356, T195, R-303, B229)
   |    | ['Button4', «Кнопка свернуть», «минимизировать»]
   |    | child_window(title="свернуть", control_type="Button")
   |    | 
   |    | Button - «максимизировать»    (L-303, T195, R-251, B229)
   |    | ['Button5', «максимизировать», 'Максимизировать Кнопку']
   |    | child_window(title="Развернуть", control_type="Button")
   |    | 
   |    | Button - «закрытие»    (L-251, T195, R-198, B229)
   |    | ['Button6', «закрытие», 'Закрыть Кнопку']
   |    | child_window(title="Закрыть", control_type="Button")
Control Identifiers:

Document - ''    (L-1505, T280, R-199, B879)
['Document']

вопрос

app = Application(backend="uia").start("notepad.exe") Невозможно запустить нормально

Язык кода:Python
копировать
app = Application(backend="uia").start("notepad.exe")
print(app.process)

Напечатанный идентификатор процесса 2643, но фактический идентификатор процесса 836, в результате чего элемент не найден:
pywinauto.findwindows.ElementNotFoundError: {'title': 'Без названия - Notepad', 'control_type': 'Window', 'backend': 'uia', 'process': 21300}

Кто знает, может помочь ответить на этот вопрос, большое спасибо.

селектор компонентов и print_control_identifiers Печатные компоненты не совпадают.

  • Используются несколько селекторов компонентов: Inspect.exe, Spy++, по ощущениям Inspect.exe Лучше всего использовать, но селектор компонентов èДерево компонентов не соответствует, распечатанное дерево компонентов должно иметь преимущественную силу.
  • Например, что касается компонента поля ввода в приведенной выше демонстрации:
  • Распечатать результат дерева компонентов:
Язык кода:txt
копировать
   |    | Document - ''    (L-1505, T280, R-199, B879)
   |    | ['Document', 'Без названияDocument']
  • Результаты Inspect.exe:
  • В результате Inspect.exe есть поле имени, но на самом деле у компонента нет имени. Использование имени приведет к тому, что компонент не будет соответствовать.

Вопрос о расположении нескольких одинаковых компонентов

  • При использовании метода child_window для поиска элементов компонента мы можем найти несколько компонентов, используя одно условие. Мы можем использовать несколько условий для максимально возможного определения уникальных элементов, например следующие условия:

ссылка

Профиль

👋 привет, я Lorin Лорейн, один Java Разработчик бэкэнд-технологий!девиз:Technology has the power to make the world a better place.

🚀 Моя страсть к технологиям — это моя мотивация продолжать учиться и делиться ими. Мой блог — это место об экосистеме Java, серверной разработке и последних технологических тенденциях.

🧠 Будучи энтузиастом серверных технологий Java, я не только с энтузиазмом изучаю новые возможности языка и глубину технологий, но также с радостью делюсь своими идеями и передовым опытом. Я верю, что обмен знаниями и сотрудничество с сообществом могут помочь нам расти вместе.

💡 В моем блоге вы найдете информацию об основных концепциях Java, JVM. В основе технологии лежат общие фреймворки, такие как Spring и Mybatis. 、Управление базами данных, например MySQL、RabbitMQ、Rocketmq и другое промежуточное программное обеспечение для сообщений、Оптимизация производительности и другой контентиз Подробная статья。Я также поделюсь некоторыми советами и решениями по программированию.вопросизметод,Чтобы помочь вам лучше освоить программирование на Java.

🌐 Я поощряю взаимодействие и создание сообщества,Поэтому, пожалуйста, оставляйте свои вопросы, предложения или пожелания по теме.,Дайте мне знать, что вас интересует. также,Я поделюсь последними новостями Интернета и технологий.,Чтобы вы всегда были в курсе последних событий в мире технологий. Я с нетерпением жду возможности двигаться вперед по пути технологий вместе с вами.,Давайте исследуем безграничные возможности мира технологий.

📖 Следите за обновлениями моего блога и давайте вместе стремиться к техническому совершенству.

Я участвую в последнем конкурсе эссе для специального учебного лагеря Tencent Technology Creation 2024. Приходите и разделите со мной приз!

boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose