首页 > 编程语言 >n、Appium_Python_Api

n、Appium_Python_Api

时间:2023-08-13 09:03:11浏览次数:47  
标签:Appium name Python text self driver element Api find

一、Appium_Python_Api方法

参考博客:https://blog.csdn.net/ezreal_tao/article/details/80911950

https://cloud.tencent.com/developer/article/1569596

  1. contexts

contexts(self):

Returns the contexts within the current session.
返回当前会话中的上下文,使用后可以识别H5页面的控件

:Usage:
	driver.contexts
用法 
	driver.contexts
  1. current_context

current_context(self):

Returns the current context of the current session.
返回当前会话的当前上下文
:Usage:
	driver.current_context
用法
	driver.current_context
  1. context

context(self):

Returns the current context of the current session.
返回当前会话的当前上下文。
:Usage:
	driver.context
用法
	driver. Context
  1. find_element_by_ios_uiautomation

find_element_by_ios_uiautomation(self, uia_string):

Finds an element by uiautomation in iOS.
通过iOS uiautomation查找元素
:Args:
	- uia_string - The element name in the iOS UIAutomation library

:Usage:
	driver.find_element_by_ios_uiautomation('.elements()[1].cells()[2]')
用法
	driver.find_element_by_ios_uiautomation(‘elements’)
  1. find_element_by_accessibility_id

find_element_by_accessibility_id(self, id):

Finds an element by accessibility id.
通过accessibility id查找元素
:Args:
	- id - a string corresponding to a recursive element search using the
Id/Name that the native Accessibility options utilize

:Usage:
	driver.find_element_by_accessibility_id()
用法
	driver.find_element_by_accessibility_id(‘id’)
  1. scroll

scroll(self, origin_el, destination_el):

Scrolls from one element to another    
从元素origin_el滚动至元素destination_el    
:Args:     
	- originalEl - the element from which to being scrolling     
    - destinationEl - the element to scroll to 
               
:Usage:        
	driver.scroll(el1, el2)
用法
	driver.scroll(el1,el2)
  1. drag_and_drop

drag_and_drop(self, origin_el, destination_el):

Drag the origin element to the destination element
将元素origin_el拖到目标元素destination_el
:Args:
	- originEl - the element to drag
    - destinationEl - the element to drag to
用法 
	driver.drag_and_drop(el1,el2)
  1. tap

tap(self, positions, duration=None):

Taps on an particular place with up to five fingers, holding for a certain time
模拟手指点击(最多五个手指),可设置按住时间长度(毫秒)
:Args:
     - positions - an array of tuples representing the x/y coordinates of the fingers to tap. Length can be up to five.
     - duration - (optional) length of time to tap, in ms

:Usage:
	driver.tap([(100, 20), (100, 60), (100, 100)], 500)
用法 
	driver.tap([(x,y),(x1,y1)],500)
  1. swipe

swipe(self, start_x, start_y, end_x, end_y, duration=None):

Swipe from one point to another point, for an optional duration.    
从A点滑动至B点,滑动时间为毫秒    
:Args:     
	- start_x - x-coordinate at which to start     
    - start_y - y-coordinate at which to start     
    - end_x - x-coordinate at which to stop     
    - end_y - y-coordinate at which to stop     
    - duration - (optional) time to take the swipe, in ms.    

:Usage:        
	driver.swipe(100, 100, 100, 400)
用法 
	driver.swipe(x1,y1,x2,y2,500)
  1. flick

flick(self, start_x, start_y, end_x, end_y):

Flick from one point to another point.    
按住A点后快速滑动至B点    
:Args:     
	- start_x - x-coordinate at which to start     
    - start_y - y-coordinate at which to start     
    - end_x - x-coordinate at which to stop     
    - end_y - y-coordinate at which to stop    
:Usage:
	driver.flick(100, 100, 100, 400)
用法 
	driver.flick(x1,y1,x2,y2)
  1. pinch

pinch(self, element=None, percent=200, steps=50):

Pinch on an element a certain amount
在元素上执行模拟双指捏(缩小操作)
:Args:
	- element - the element to pinch
    - percent - (optional) amount to pinch. Defaults to 200%
    - steps - (optional) number of steps in the pinch action

:Usage:
	driver.pinch(element)
  1. zoom

zoom(self, element=None, percent=200, steps=50):

Zooms in on an element a certain amount
在元素上执行放大操作
:Args:
	- element - the element to zoom
    - percent - (optional) amount to zoom. Defaults to 200%
    - steps - (optional) number of steps in the zoom action

:Usage:
	driver.zoom(element)
用法 
	driver.zoom(element) 
  1. reset reset(self):
Resets the current application on the device.
重置应用(类似删除应用数据)
用法 
	driver.reset()
  1. hide_keyboard

hide_keyboard(self, key_name=None, key=None, strategy=None):

Hides the software keyboard on the device. In iOS, use `key_name` to press a particular key, or `strategy`. In Android, no parameters are used.
隐藏键盘,iOS使用key_name隐藏,安卓不使用参数
:Args:
	- key_name - key to press
    - strategy - strategy for closing the keyboard (e.g., `tapOutside`)

driver.hide_keyboard()
  1. keyevent

keyevent(self, keycode, metastate=None):

Sends a keycode to the device. Android only. Possible keycodes can be found in http://developer.android.com/reference/android/view/KeyEvent.html.
发送按键码(安卓仅有),按键码可以上网址中找到
:Args:
	- keycode - the keycode to be sent to the device
    - metastate - meta information about the keycode being sent
用法 
	dr.keyevent(‘4’)
  1. press_keycode

press_keycode(self, keycode, metastate=None):

Sends a keycode to the device. Android only. Possible keycodes can be found in http://developer.android.com/reference/android/view/KeyEvent.html.
发送按键码(安卓仅有),按键码可以上网址中找到
:Args:
	- keycode - the keycode to be sent to the device
    - metastate - meta information about the keycode being sent

用法 
	driver.press_ keycode(‘4’)
dr.keyevent(‘4’)与driver.press_ keycode(‘4’) 功能实现上一样的,都是按了返回键
  1. long_press_keycode

long_press_keycode(self, keycode, metastate=None):

Sends a long press of keycode to the device. Android only. Possible keycodes can be found in http://developer.android.com/reference/android/view/KeyEvent.html.
发送一个长按的按键码(长按某键)
详细的按键代码见这里  http://developer.android.com/reference/android/view/KeyEvent.html.
:Args:
	- keycode - the keycode to be sent to the device
    - metastate - meta information about the keycode being sent
    
 用法 
 	driver.long_press_keycode(4) 
  1. current_activity

current_activity(self):

Retrieves the current activity on the device.
获取当前的activity

用法 
	print(driver.current_activity)
  1. wait_activity

wait_activity(self, activity, timeout, interval=1):

Wait for an activity: block until target activity presents or time out. This is an Android-only method.
等待指定的activity出现直到超时,interval为扫描间隔1秒即每隔几秒获取一次当前的activity返回的True 或 False
:Agrs:
	- activity - target activity
    - timeout - max wait time, in seconds
    - interval - sleep interval between retries, in seconds

用法
	driver.wait_activity(‘.activity.xxx’,5,2)
  1. background_app

background_app(self, seconds):

Puts the application in the background on the device for a certain duration.
后台运行app多少秒
:Args:
	- seconds - the duration for the application to remain in the background
    
用法 
driver.background_app(5)   置后台5秒后再运行
  1. is_app_installed

is_app_installed(self, bundle_id):

Checks whether the application specified by `bundle_id` is installed on the device.
检查app是否有安装返回 True or False
:Args:
	- bundle_id - the id of the application to query

用法 
driver.is_app_installed(“com.xxxx”)
  1. install_app

install_app(self, app_path):

Install the application found at `app_path` on the device.
安装app,app_path为安装包路径
:Args:
	- app_path - the local or remote path to the application to install

用法 
	driver.install_app(app_path)
  1. remove_app

remove_app(self, app_id):

Remove the specified application from the device.    
删除app    
:Args:     
	- app_id - the application id to be removed
    
用法 
	driver.remove_app(“com.xxx.”)
  1. launch_app

launch_app(self):

Start on the device the application specified in the desired capabilities.
启动app

用法 
	driver.launch_app()
  1. close_app

close_app(self):

Stop the running application, specified in the desired capabilities, on the device.
关闭app

用法 
	driver.close_app() 启动和关闭app运行好像会出错
  1. start_activity

start_activity(self, app_package, app_activity, **opts):

Opens an arbitrary activity during a test. If the activity belongs to another application, that application is started and the activity is opened. This is an Android-only method.
在测试过程中打开任意活动。如果活动属于另一个应用程序,该应用程序的启动和活动被打开。这是一个安卓的方法
:Args:
	- app_package - The package containing the activity to start.
    - app_activity - The activity to start.
    - app_wait_package - Begin automation after this package starts (optional).
    - app_wait_activity - Begin automation after this activity starts (optional).
    - intent_action - Intent to start (optional).
    - intent_category - Intent category to start (optional).
    - intent_flags - Flags to send to the intent (optional).
    - optional_intent_arguments - Optional arguments to the intent (optional).
    - stop_app_on_reset - Should the app be stopped on reset (optional)

用法 
	driver.start_activity(app_package, app_activity)
  1. lock

lock(self, seconds):

Lock the device for a certain period of time. iOS only.
锁屏一段时间  iOS专有
:Args:
	- the duration to lock the device, in seconds

用法 
	driver.lock()
  1. shake

shake(self):

Shake the device.
摇一摇手机

用法 
	driver.shake()
  1. open_notifications

open_notifications(self):

Open notification shade in Android (API Level 18 and above)
打开系统通知栏(仅支持API 18 以上的安卓系统)

用法 
	driver.open_notifications()
  1. network_connection

network_connection(self):

Returns an integer bitmask specifying the network connection type. Android only.
返回网络类型  数值
Possible values are available through the enumeration `appium.webdriver.ConnectionType`

用法 
	driver.network_connection()
  1. set_network_connection

set_network_connection(self, connectionType):

Sets the network connection type. Android only.
Possible values:
    Value (Alias)      | Data | Wifi | Airplane Mode
        -------------------------------------------------
        0 (None)           | 0    | 0    | 0
    1 (Airplane Mode)  | 0    | 0    | 1
    2 (Wifi only)      | 0    | 1    | 0
    4 (Data only)      | 1    | 0    | 0
    6 (All network on) | 1    | 1    | 0
These are available through the enumeration `appium.webdriver.ConnectionType`
设置网络类型
:Args:
	- connectionType - a member of the enum appium.webdriver.ConnectionType

用法  
# 先加载
from appium.webdriver.connectiontype import ConnectionTypedr
ConnectionTypedr.set_network_connection(ConnectionType.WIFI_ONLY)
ConnectionType的类型有:
    NO_CONNECTION = 0
    AIRPLANE_MODE = 1
    WIFI_ONLY = 2
    DATA_ONLY = 4
    ALL_NETWORK_ON = 6
  1. available_ime_engines

available_ime_engines(self):

Get the available input methods for an Android device. Package and activity are returned (e.g., ['com.android.inputmethod.latin/.LatinIME']) Android only.
返回安卓设备可用的输入法

用法
	print(driver.available_ime_engines)
  1. is_ime_active

is_ime_active(self):

Checks whether the device has IME service active. Returns True/False. Android only.
检查设备是否有输入法服务活动。返回真/假。安卓专有

用法 
	print(driver.is_ime_active())
  1. activate_ime_engine

activate_ime_engine(self, engine):

Activates the given IME engine on the device. Android only.
激活安卓设备中的指定输入法,设备可用输入法可以从“available_ime_engines”获取
:Args:
	- engine - the package and activity of the IME engine to activate (e.g., 'com.android.inputmethod.latin/.LatinIME')

用法 
	driver.activate_ime_engine(“com.android.inputmethod.latin/.LatinIME”)
  1. deactivate_ime_engine

deactivate_ime_engine(self):

Deactivates the currently active IME engine on the device. Android only.
关闭安卓设备当前的输入法

用法 
	driver.deactivate_ime_engine()
  1. active_ime_engine

active_ime_engine(self):

Returns the activity and package of the currently active IME engine (e.g., 'com.android.inputmethod.latin/.LatinIME'). Android only.
返回当前输入法的包名

用法 
	driver.active_ime_engine()
  1. toggle_location_services

toggle_location_services(self):

Toggle the location services on the device. Android only.
打开安卓设备上的位置定位设置

用法 
	driver.toggle_location_services()
  1. set_location

set_location(self, latitude, longitude, altitude):

Set the location of the device
设置设备的经纬度
:Args:
	- latitude纬度 - String or numeric value between -90.0 and 90.00
    - longitude经度 - String or numeric value between -180.0 and 180.0
	- altitude海拔高度- String or numeric value
    
用法
	driver.set_location(纬度,经度,高度)
  1. tag_name

tag_name(self):

This element's ``tagName`` property.
返回元素的tagName属性,经实践返回的是class name

用法
	element.tag_name()
  1. text

text(self):

The text of the element.
返回元素的文本值

用法 
	element.text
  1. click

click(self):

Clicks the element.
点击元素

用法
	element.click()
  1. submit

submit(self):

Submits a form.
提交表单

用法
	暂无
  1. clear

clear(self):

Clears the text if it's a text entry element.    
清除输入的内容

用法
	element.clear()
  1. get_attribute

get_attribute(self, name): 详见@chenhengjie123超级链接

Gets the given attribute or property of the element.
	1、获取 content-desc 的方法为 get_attribute("name") ,而且还不能保证返回的一定是 content-desc (content-desc 为空时会返回 text 属性值)
	2、get_attribute 方法不是我们在 uiautomatorviewer 看到的所有属性都能获取的(此处的名称均为使用 get_attribute 时使用的属性名称):
    可获取的字符串类型:
    	name(返回 content-desc 或 text)
		text(返回 text)
		className(返回 class,只有 API=>18 才能支持)
		resourceId(返回 resource-id,只有 API=>18 才能支持)
    This method will first try to return the value of a property with the given name. If a property with that name doesn't exist, it returns the value of the attribute with the same name. If there's no attribute with that name, ``None`` is returned. Values which are considered truthy, that is equals "true" or "false", are returned as booleans.  All other non-``None`` values are returned as strings. For attributes or properties which do not exist, ``None`` is returned.

:Args:
	- name - Name of the attribute/property to retrieve.

Example:
	# Check if the "active" CSS class is applied to an element.
    is_active = "active" in target_element.get_attribute("class")

用法
	暂无
  1. is_selected

is_selected(self):

Returns whether the element is selected. Can be used to check if a checkbox or radio button is selected.
返回元素是否选择。可以用来检查一个复选框或单选按钮被选中。

用法 
	element.is_slected()
  1. is_enabled

is_enabled(self):

Returns whether the element is enabled.
返回元素是否可用True of False

用法 
	element.is_enabled()
  1. find_element_by_id

find_element_by_id(self, id_):

Finds element within this element's children by ID.    
通过元素的ID定位元素 
:Args:
	- id_ - ID of child element to locate.
    
用法 
	driver.find_element_by_id(“id”)
  1. find_elements_by_id

find_elements_by_id(self, id_):

Finds a list of elements within this element's children by ID.    
通过元素ID定位,含有该属性的所有元素    
:Args:        
	- id_ - Id of child element to find.
    
用法 
	driver.find_elements_by_id(“id”)
  1. find_element_by_name

find_element_by_name(self, name):

Finds element within this element's children by name.     
通过元素Name定位(元素的名称属性text)    
:Args:
	- name - name property of the element to find.
    
用法 
	driver.find_element_by_name(“name”)
  1. find_elements_by_name

find_elements_by_name(self, name):

Finds a list of elements within this element's children by name.    
通过元素Name定位(元素的名称属性text),含有该属性的所有元素    
:Args:
	- name - name property to search for.
    
用法 
	driver.find_element_by_name(“name”)
  1. find_element_by_link_text

find_element_by_link_text(self, link_text):

Finds element within this element's children by visible link text.    
通过元素可见链接文本定位    
:Args:        
	- link_text - Link text string to search for.
    
用法 
	driver.find_element_by_link_text(“text”)
  1. find_elements_by_link_text

find_element_by_link_text(self, link_text):

Finds a list of elements within this element's children by visible link text    
通过元素可见链接文本定位,含有该属性的所有元素    
:Args:        
	- link_text - Link text string to search for.

用法 
	driver.find_elements_by_link_text(“text”)
  1. find_element_by_partial_link_text

find_element_by_partial_link_text(self, link_text):

Finds element within this element's children by partially visible link text.    
通过元素部分可见链接文本定位    
:Args:        
	- link_text - Link text string to search for.driver. 
    
用法
	find_element_by_partial_link_text(“text”)
  1. find_elements_by_partial_link_text

find_elements_by_partial_link_text(self, link_text):

Finds a list of elements within this element's children by link text.    
通过元素部分可见链接文本定位,含有该属性的所有元素    
:Args:        
	- link_text - Link text string to search for.driver. 
    
用法
	find_elements_by_partial_link_text(“text”)
  1. find_element_by_tag_name

find_element_by_tag_name(self, name):

Finds element within this element's children by tag name.    
通过查找html的标签名称定位元素    
:Args:
	- name - name of html tag (eg: h1, a, span)

用法
	driver.find_element_by_tag_name(“name”)
  1. find_elements_by_tag_name

find_elements_by_tag_name(self, name):

Finds a list of elements within this element's children by tag name.   
通过查找html的标签名称定位所有元素    
:Args:        
	- name - name of html tag (eg: h1, a, span)

用法
	driver.find_elements_by_tag_name(“name”)
  1. find_element_by_xpath

find_element_by_xpath(self, xpath):

Finds element by xpath.
通过Xpath定位元素,详细方法可参阅http://www.w3school.com.cn/xpath/
:Args:
	- xpath - xpath of element to locate.  "//input[@class='myelement']"

Note: 
The base path will be relative to this element's location. 
This will select the first link under this element. ::
	myelement.find_elements_by_xpath(".//a")
However, this will select the first link on the page. ::
	myelement.find_elements_by_xpath("//a")

用法 
	find_element_by_xpath(“//*”)
  1. find_elements_by_xpath

find_elements_by_xpath(self, xpath):

Finds elements within the element by xpath.
:Args:
	- xpath - xpath locator string.

Note: The base path will be relative to this element's location.    
This will select all links under this element. ::
	myelement.find_elements_by_xpath(".//a")    
However, this will select all links in the page itself. ::
	myelement.find_elements_by_xpath("//a")

用法
	find_elements_by_xpath(“//*”)
  1. find_element_by_class_name

find_element_by_class_name(self, name):

Finds element within this element's children by class name.    
通过元素class name属性定位元素    
:Args:
	- name - class name to search for.
    
用法 
	driver.find_element_by_class_name(“android.widget.LinearLayout”)
  1. find_elements_by_class_name

find_elements_by_class_name(self, name):

Finds a list of elements within this element's children by class name.    
通过元素class name属性定位所有含有该属性的元素    
:Args:
	- name - class name to search for.
    
用法 
	driver.find_elements_by_class_name(“android.widget.LinearLayout”)
  1. find_element_by_css_selector

find_element_by_css_selector(self, css_selector):

Finds element within this element's children by CSS selector.    
通过CSS选择器定位元素    
:Args:
	- css_selector - CSS selctor string, ex: 'a.nav#home'
  1. send_keys

send_keys(self, *value):

Simulates typing into the element.
在元素中模拟输入(开启appium自带的输入法并配置了appium输入法后,可以输入中英文)
:Args:
	- value - A string for typing, or setting form fields. For setting file inputs, this could be a local file path.
	Use this to send simple key events or to fill out form fields ::
    	form_textfield = driver.find_element_by_name('username')
        form_textfield.send_keys("admin")
    This can also be used to set file inputs. ::
        file_input = driver.find_element_by_name('profilePic')
        file_input.send_keys("path/to/profilepic.gif")
        # Generally it's better to wrap the file path in one of the methods
        # in os.path to return the actual path to support cross OS testing.
        # file_input.send_keys(os.path.abspath("path/to/profilepic.gif"))driver.element.send_keys(“中英”)
  1. is_displayed

is_displayed(self):

Whether the element is visible to a user.    
此元素用户是否可见。简单地说就是隐藏元素和被控件挡住无法操作的元素(仅限 Selenium,appium是否实现了类似功能不是太确定)这一项都会返回 False

用法 
	driver.element.is_displayed()
  1. location_once_scrolled_into_view

location_once_scrolled_into_view(self):

"""
THIS PROPERTY MAY CHANGE WITHOUT WARNING. Use this to discover
    where on the screen an element is so that we can click it. This method should cause the element to be scrolled into view.
    Returns the top lefthand corner location on the screen, or ``None`` if the element is not visible.
    暂不知道用法
"""
  1. size

size(self):

The size of the element.
获取元素的大小(高和宽)
new_size["height"] = size["height"]
new_size["width"] = size["width"]

用法 
	driver.element.size
  1. value_of_css_property

value_of_css_property(self, property_name):

The value of a CSS property.
CSS属性

用法 
	暂不知
  1. location

location(self):

The location of the element in the renderable canvas.
获取元素左上角的坐标 

用法 
	driver.element.location
	'''返回element的x坐标, int类型'''
	driver.element.location.get('x')
	'''返回element的y坐标, int类型'''
	driver.element.location.get('y')
  1. rect

rect(self):

A dictionary with the size and location of the element.
元素的大小和位置的字典
  1. screenshot_as_base64

screenshot_as_base64(self):

Gets the screenshot of the current element as a base64 encoded string.
获取当前元素的截图为Base64编码的字符串
:Usage:
	img_b64 = element.screenshot_as_base64
  1. execute_script

execute_script(self, script, *args):

Synchronously Executes JavaScript in the current window/frame. 
在当前窗口/框架(特指 Html 的 iframe )同步执行 javascript 代码。你可以理解为如果这段代码是睡眠5秒,这五秒内主线程的 javascript 不会执行
:Args:
	- script: The JavaScript to execute.
    - *args: Any applicable arguments for your JavaScript.

:Usage:
	driver.execute_script('document.title')
  1. execute_async_script

execute_async_script(self, script, *args):

Asynchronously Executes JavaScript in the current window/frame.
插入 javascript 代码,只是这个是异步的,也就是如果你的代码是睡眠5秒,那么你只是自己在睡,页面的其他javascript 代码还是照常执行
:Args:
	- script: The JavaScript to execute.
    - *args: Any applicable arguments for your JavaScript.

:Usage:
	driver.execute_async_script('document.title')
  1. current_url

current_url(self):

Gets the URL of the current page.
获取当前页面的网址。
:Usage:
	driver.current_url

用法 
	driver.current_url()
  1. page_source

page_source(self):

Gets the source of the current page.
获取当前页面的源。
:Usage:
	driver.page_source
  1. close

close(self):

Closes the current window.
关闭当前窗口
:Usage:
	driver.close()
  1. quit

quit(self):

Quits the driver and closes every associated window.
退出脚本运行并关闭每个相关的窗口连接
:Usage:
	driver.quit()
  1. get_screenshot_as_file

get_screenshot_as_file(self, filename):

Gets the screenshot of the current window. Returns False if there is any IOError, else returns True. Use full paths in your filename.
截取当前窗口的截图,如果有写入错误会返回False,其它返回True. filename 使用绝对路径
:Args:
	- filename: The full path you wish to save your screenshot to.

:Usage:
	driver.get_screenshot_as_file('c:/foo.png')
  1. get_window_size

get_window_size(self, filename):

Gets the width and height of the current window.
获取当前屏幕的分辨率(长和宽)
:Usage:
	driver.get_window_size()

二、整理

global driver

# 元素定位
driver.find_element_by_id("id") # id定位
driver.find_element_by_name("name") # name定位
driver.find_element_by_link_text("text") # 链接名定位
driver.find_element_by_partial_link_text("text") # 通过元素部分可见链接文本定位
driver.find_element_by_tag_name("name") # 通过查找html的标签名称定位元素
driver.find_element_by_xpath("xpath") # 路径定位
driver.find_element_by_class_name("android.widget.LinearLayout") # 类名定位
driver.find_element_by_css_selector("css") # css选择器定位

# 元素集合复数定位
driver.find_elements_by_id("id") # id元素集合
driver.find_elements_by_name("name") # name元素集合
driver.find_elements_by_link_text("text") # 链接名元素集合
driver.find_elements_by_partial_link_text("text") # 部分元素可见链接集合
driver.find_elements_by_tag_name("name") # html标签名集合
driver.find_elements_by_xpath("xpath") # 路径定位集合
driver.find_elements_by_class_name("android.widget.LinearLayout") # 类名定位集合
driver.find_elements_by_css_selector("css") # css选择器定位集合

# 输入框输入
driver.element.send_keys("中英")

# 锁定屏幕
driver.lock(5)

# 把当前应用置于后台
driver.background_app(5)

# 收起键盘
driver.hide_keyboard()

# 打开一个应用或者activity,仅安卓端
driver.start_activity('com.example.android.apis', '.Foo')

# 打开下拉通知栏,仅安卓端
driver.open_notifications()

# 拖动元素,将元素origin_el拖到目标元素destination_el
driver.drag_and_drop(self, origin_el, destination_el):

# 检查app是否已安装
driver.is_app_installed('com.example.android.apis')

# 安装应用到设备
driver.install_app('path/to/my.apk')

# 删除应用
driver.remove_app('com.example.android.apis')

# 模拟设备摇晃
driver.shake()

# 关闭应用
driver.close_app()

# 启动 (Launch)
# 根据服务关键字 (desired capabilities) 启动会话 (session) 。请注意这必须在设定 autoLaunch=false 关键字时才能生效。
# 这不是用于启动指定的 app/activities ————你可以使用 start_activity 做到这个效果————
# 这是用来继续进行使用了 autoLaunch=false 关键字时的初始化 (Launch) 流程的。
driver.launch_app()

# 应用重置,相当于重新卸载安装
driver.reset()

# 可用上下文 (context) 列出所有的可用上下文
# 翻译备注:context可以理解为可进入的窗口。例如,对于原生应用,可用的context和默认context均为NATIVE_APP。
# 详情可查看对混合应用进行自动化测试
driver.contexts

# 列出当前上下文
driver.current_context

# 切换到默认的上下文 (context)
# 将上下文切换到默认上下文
driver.switch_to.context(None)

# 获取应用的字符串
driver.app_strings

# 按键事件 (Key Event)给设备发送一个按键事件
driver.keyevent(176)

# 获取当前的activity
driver.current_activity

# 触摸动作(TouchAction) / 多点触摸动作(MultiTouchAction)
action = TouchAction(driver)
action.press(element=el, x=10, y=10).release().perform()

# 滑动(Swipe)模拟用户滑动
# 注意:appium滑动规则是x从左到右变大,y从上到下变大
driver.swipe(start=75, starty=500, endx=75, endy=0, duration=800)

# 捏 (Pinch)捏屏幕 (双指往内移动来缩小屏幕)
driver.pinch(element=el)

# 放大 (Zoom)放大屏幕 (双指往外移动来放大屏幕)
driver.zoom(element=el)

# 滑动到某个元素 (Scroll To)
# todo: python
driver.scroll(el1, el2)

# 从设备中拉出文件 (Pull File)
driver.pull_file('Library/AddressBook/AddressBook.sqlitedb')

# 推送文件到设备中去
data = "some data for the file"
path = "/data/local/tmp/file.txt"
driver.push_file(path, data.encode('base64'))

# 断言
Assert.assertEquals("I am a div", div.getText()); //跳转到指定页面并在该页面所以用元素id进行交互

# 检查文本是否符合预期
assertEqual('I am a div', div.text)

# 输入法是否有活动 返回真假
is_ime_active(self):

# 返回当前安卓设备可用的输入法
driver.available_ime_engines(self):

# 激活安卓设备中的制定输入法
driver.activate_ime_engine(self, engine):

# 关闭当前的输入法(android)
driver.deactivate_ime_engine(self):

# 打开安卓设备上的位置定位设置
driver.toggle_location_services()

# 设置设备的经纬度
:Args:
	- latitude纬度 - String or numeric value between -90.0 and 90.00
    - longitude经度 - String or numeric value between -180.0 and 180.0
    - altitude海拔高度- String or numeric value
用法 
	driver.set_location(纬度,经度,高度)

# 点击
element.click()

# 清除元素内容
element.clear()

# 返回元素的文本内容
element.text()

# 提交表单
element.submit(self):

# 元素是否可用
element.is_enabled()

# 元素是否可选
element.is_slected()

# 元素是否可见
element.is_displayed()

# 获取元素的大小(高和宽)
new_size["height"] = size["height"]
new_size["width"] = size["width"]
driver.element.size

# 获取元素左上角的坐标
# 用法 
    driver.element.location
    '''返回element的x坐标, int类型'''
    driver.element.location.get('x')
    '''返回element的y坐标, int类型'''
    driver.element.location.get('y')

# 获取当前元素的截图为Base64编码的字符串
img_b64 = element.screenshot_as_base64

# 执行JS
# 在当前窗口/框架(特指 Html 的 iframe )同步执行 javascript 代码
driver.execute_script('document.title')

# 异步执行代码,其他代码在执行
driver.execute_async_script('document.title')

# 获取当前url
driver.current_url

# 获取页面源
driver.page_source

# 关闭当前窗口
driver.close()

# 关闭应用
driver.quit()

# chrome上进行测试
{
    'platformName': 'Android',
    'platformVersion': '4.4',
    'deviceName': 'Android Emulator',
    'browserName': 'Chrome'
}

# 真机测试
{
    'automationName': 'Selendroid',
    'platformName': 'Android',
    'platformVersion': '2.3',
    'deviceName': 'Android Emulator',
    'app': myApp,
    'appPackage': 'com.mycompany.package',
    'appActivity': '.MainActivity'
}

# 多点触控
"""
规范中的可用事件有:
* 短按 (press)
* 释放 (release)
* 移动到 (moveTo)
* 点击 (tap)
* 等待 (wait)
* 长按 (longPress)
* 取消 (cancel)
* 执行 (perform)
  """

标签:Appium,name,Python,text,self,driver,element,Api,find
From: https://www.cnblogs.com/simpleness/p/17626086.html

相关文章

  • python简介
    python简介1.python的产生与应用python于1989年圣诞节期间由吉多·范罗苏姆(GuidovanRossum)(中文名字:龟叔)为打发时间开发的一个新脚本解释程序,作为ABC语言的一种继承。(龟叔:2005年加入谷歌至2012年,2013年加入Dropbox直到现在,依然掌握着Python发展的核心方向,被称为仁慈的独裁者)。......
  • python基础
    python基础一、python基础初识1.运行python代码。在d盘下创建一个t1.py文件内容是:print('helloworld')打开windows命令行输入cmd,确定后写入代码pythond:t1.py您已经运行了第一个python程序,即:终端---->cmd----->python文件路径。回车搞定~2.解释器。上一步中执......
  • 某公司笔试题 - 坐标移动(附python代码)
    #开发一个坐标计算工具,A表示向左移动,D表示向右移动,W表示向上移动,S表示向下移动。从(0,0)点开始移动,从输入字符串里面读取坐标,并将最终输入结果输出文件里面。#输入坐标为A(或D或W或S)+数字(两位以内)。坐标之间以;分隔#数据范围:1<=n<=10000每组输入的字符串长度坐标保证满足-......
  • python案例
    这猜单词游戏。具体步骤如下:导入random模块,用于随机选择单词。设置初始生命次数为3。创建一个单词列表words,其中包含了一些单词。使用random.choices()函数从单词列表中随机选择一个单词作为秘密单词secret_word。创建一个clue列表,用于表示未猜中的字母的占位符。初始时,将cl......
  • Python微信公众号文章批量转pdf
    文章来源:https://www.cnblogs.com/MrFlySand/p/17216072.html操作步骤下载离线html网页文件1、登录微信公众号后台,打开“文章发表记录”。按Ctrl+S保存离线html网页文件。3、记住html文件保存路径,设置html文件名称。4、点击第2页的文章发表记录,重复步骤2、步骤3的操......
  • 某公司笔试题 - 求int型正整数在内存中存储时1的个数(附python代码)
    #输入一个int型的正整数,计算出该int型数据在内存中存储时1的个数。#数据范围:保证在32位整型数字范围内num=int(input("请输入一个正整数:"))#将输入的正整数转化成二进制num_bin=bin(num)print(num_bin)#将二进制字符串转化成数组nbl=list(num_bin)iflen(nbl)>0and......
  • 某公司笔试题 - 字符串排序(附python代码)
    #给定n个字符串,请对n个字符串按照字典序排列。#数据范围:1<=n<=1000,字符串长度满足1<=len<=100times=int(input("请输入字符串的个数:"))iftimes>=1andtimes<=1000:dicts={}print("请输入字符串,回车键切换输入下一个字符串:")foriinrange(......
  • python urllib爬虫的坑 gzip.BadGzipFile: Not a gzipped file
    一句话返回的数据不是gzip加密的打印一下返回的headers数据有一个Content-Encoding就是返回数据的加密方式根据相应的解密就可以  建议把发送的请求里加密方式只留一个gzip或者其他方便解密  还有遇到一个问题就是发送请求目标网站返回的数据一会是加密的一会是原......
  • 某公司笔试题 - 句子逆序(附python代码)
    #将一个英文语句以单词为单位逆序排放。例如“Iamaboy”,逆序排放后为“boyaamI”,所有单子之间用一个空格隔开,语句中除了英文字母外,不再包含其他字符#数据范围:输入的字符串长度满足1<=n<=1000importrestr1=input("请输入一个英语句子:")#通过正则匹配输入英......
  • Python分享之 Spider
    一、网络爬虫   网络爬虫又被称为网络蜘蛛,我们可以把互联网想象成一个蜘蛛网,每一个网站都是一个节点,我们可以使用一只蜘蛛去各个网页抓取我们想要的资源。举一个最简单的例子,你在百度和谷歌中输入‘Python',会有大量和Python相关的网页被检索出来,百度和谷歌是如何从海量的网页......