用Python實現自動化操作Android手機


本文原創作者:鯤之鵬(http://www.site-digger.com)
本文原始鏈接:http://www.site-digger.com/html/articles/20180912/664.html

 

 


一、【必須】安裝adb工具

adb全稱Android Debug Bridge,是Android系統的調試工具。

下並安裝ADB Installer v1.4.3,下載鏈接:http://pan.webscraping.cn:8000/index.php/s/7kDAJUOmKEa1h4N 安裝完成后,啟動一個新的cmd窗口,輸入adb devices,若無錯誤提示則表明安裝成功。

Ubuntu下安裝adb可以參考這篇文章:http://bernaerts.dyndns.org/linux/74-ubuntu/354-ubuntu-xenial-android-adb-fastboot-qtadb)

二、【可選】安裝UI Automator Viewer輔助工具

為了使用UI Automator Viewer這個輔助分析工具,我們需要先安裝Android SDK,步驟如下:

1. 下載並安裝Java 8

2. 下載並安裝Google Android SDK

3. 啟動Android SDK Manager,選擇並安裝Android SDK Platform-tools.

4. 雙擊uiautomatorviewer.bat,啟動UI Automator Viewer,點擊第二個圖標獲取設備截圖及相關UI信息,如下圖所示。

三、【主角】AndroidViewClient

AndroidViewClient是用純Python編寫的Android應用程序自動測試框架,它不依賴其它程序(例如 monkeyrunner, jython)。AndroidViewClient在底層是通過調用adb命令實現對Android設備的控制,因此在本文的一開始就先介紹了adb的安裝。

開始下文之前,假設你已經安裝配置好Python運行環境,否則請先安裝Python 2.7(注意:AndroidViewClient不兼容Python3)。

1. 安裝AndroidViewClient

項目主頁:https://github.com/dtmilano/AndroidViewClient

推薦用easy_install安裝:

  1. easy_install --upgrade androidviewclient  

安裝詳細說明見這里:https://github.com/dtmilano/AndroidViewClient/wiki#installation

PS:依賴庫比較多,安裝需要有點耐心。

2. 測試安裝是否成功

下載https://github.com/dtmilano/AndroidViewClient/archive/master.zip包,解壓並切換到examples目錄下,執行python check-import.py,如果沒有問題,會輸出OK。

3. 寫一個例子

實現這樣一個功能:

點擊屏幕微信圖標啟動微信,點擊第一個聯系人/群,發送一個報時消息。

代碼如下:

  1. # coding: utf-8  
  2. # 點擊屏幕微信圖標啟動微信,點擊第一個聯系人/群,發送一個報時消息  
  3.   
  4. import sys  
  5. import os  
  6. import re  
  7. import time  
  8. from com.dtmilano.android.viewclient import ViewClient  
  9.   
  10. def test():  
  11.     # 連接手機  
  12.     device, serialno = ViewClient.connectToDeviceOrExit()  
  13.     vc = ViewClient(device, serialno)  
  14.     # 按HOME鍵  
  15.     device.press('KEYCODE_HOME')  
  16.     time.sleep(3)  
  17.     # 找到微信圖標  
  18.     vc.dump()  
  19.     weixin_button = vc.findViewWithTextOrRaise(u'微信')  
  20.     # 點擊微信圖標  
  21.     weixin_button.touch()  
  22.     time.sleep(10)  
  23.     # 找到第一個聯系人/群  
  24.     # 可以使用UI Automator Viewer查看到對應第一個聯系人/群的resource-id為"com.tencent.mm:id/auj"  
  25.     vc.dump()  
  26.     group_button = vc.findViewByIdOrRaise("com.tencent.mm:id/auj")  
  27.     # 點擊進群  
  28.     group_button.touch()  
  29.     time.sleep(5)  
  30.     # 找到輸入框並輸入當前時間  
  31.     vc.dump()  
  32.     vc.findViewByIdOrRaise("com.tencent.mm:id/aep").setText('Now:{}'.format(time.strftime('%Y-%m-%d %H:%M:%S')))  
  33.     time.sleep(3)  
  34.     # 點擊發送按鈕  
  35.     vc.dump()  
  36.     vc.findViewWithTextOrRaise(u'發送').touch()  
  37.         
  38. if __name__ == '__main__':  
  39.     test()  

4. 高級用法:Culebra的使用

Culebra可以幫助我們自動生成(錄制)AndroidViewClient腳本。它提供了一個GUI,當我們通過GUI上操作手機,就會自動產生AndroidViewClient控制腳本模板,我們可以再在這個模板腳本基礎上進行修改,實現更復雜的功能。Culebra的詳細說明見其主頁:https://github.com/dtmilano/AndroidViewClient/wiki/culebra

我們來做一個測試,錄制一個”點擊微信聊天文字輸入框,然后輸入一段文本test"操作的腳本: 首先啟動Culebra(culebra文件位於AndroidViewClient包的tools目錄下,我把后綴名改成.py了),命令如下:

  1. python culebra.py -G --scale 0.5  

如下所示為完成操作之后的Culebra的GUI截圖:

下面為Culebra自動錄制的腳本:

  1. #! /usr/bin/env python  
  2. # -*- coding: utf-8 -*-  
  3. import reimport sys  
  4. import os  
  5.   
  6. from com.dtmilano.android.viewclient import ViewClient  
  7.   
  8. TAG = 'CULEBRA'  
  9.   
  10. _s = 5  
  11. _v = '--verbose' in sys.argv  
  12.   
  13.   
  14. kwargs1 = {'ignoreversioncheck': False, 'verbose': False, 'ignoresecuredevice': False}  
  15. device, serialno = ViewClient.connectToDeviceOrExit(**kwargs1)  
  16. kwargs2 = {'forceviewserveruse': False, 'useuiautomatorhelper': False, 'ignoreuiautomatorkilled': True, 'autodump': False, 'debug': {}, 'startviewserver': True, 'compresseddump': True}  
  17. vc = ViewClient(device, serialno, **kwargs2)  
  18. #vc.dump(window='-1') # FIXME: seems not needed  
  19.   
  20. vc.dump(window=-1)  
  21.   
  22. no_id1 = vc.findViewByIdOrRaise("id/no_id/1")  
  23. no_id1 = vc.findViewWithContentDescriptionOrRaise(u'''''當前所在頁面,與家好月圓(19)的聊天''')  
  24. com_tencent_mm___id_ds5 = vc.findViewByIdOrRaise("com.tencent.mm:id/ds5")  
  25. com_tencent_mm___id_cgo = vc.findViewByIdOrRaise("com.tencent.mm:id/cgo")  
  26. com_tencent_mm___id_ts = vc.findViewByIdOrRaise("com.tencent.mm:id/ts")  
  27. com_tencent_mm___id_iz = vc.findViewByIdOrRaise("com.tencent.mm:id/iz")  
  28. com_tencent_mm___id_j0 = vc.findViewByIdOrRaise("com.tencent.mm:id/j0")  
  29. com_tencent_mm___id_j0 = vc.findViewWithContentDescriptionOrRaise(u'''''返回''')  
  30. com_tencent_mm___id_j1 = vc.findViewByIdOrRaise("com.tencent.mm:id/j1")  
  31. com_tencent_mm___id_j1 = vc.findViewWithTextOrRaise(u'家好月圓(19)')  
  32. com_tencent_mm___id_iw = vc.findViewByIdOrRaise("com.tencent.mm:id/iw")  
  33. com_tencent_mm___id_iw = vc.findViewWithContentDescriptionOrRaise(u'''''聊天信息''')  
  34. no_id9 = vc.findViewByIdOrRaise("id/no_id/9")  
  35. no_id10 = vc.findViewByIdOrRaise("id/no_id/10")  
  36. com_tencent_mm___id_lz = vc.findViewByIdOrRaise("com.tencent.mm:id/lz")  
  37. no_id12 = vc.findViewByIdOrRaise("id/no_id/12")  
  38. # ......  
  39. # 省略多行類似代碼  
  40. # ......  
  41. com_tencent_mm___id_aen = vc.findViewWithContentDescriptionOrRaise(u'''''切換到按住說話''')  
  42. com_tencent_mm___id_aeo = vc.findViewByIdOrRaise("com.tencent.mm:id/aeo")  
  43. com_tencent_mm___id_aep = vc.findViewByIdOrRaise("com.tencent.mm:id/aep")  
  44. com_tencent_mm___id_aer = vc.findViewByIdOrRaise("com.tencent.mm:id/aer")  
  45. com_tencent_mm___id_aer = vc.findViewWithContentDescriptionOrRaise(u'''''表情''')  
  46. com_tencent_mm___id_aeu = vc.findViewByIdOrRaise("com.tencent.mm:id/aeu")  
  47. com_tencent_mm___id_aeu = vc.findViewWithContentDescriptionOrRaise(u'''''更多功能按鈕,已折疊''')  
  48.   
  49. vc.findViewByIdOrRaise("com.tencent.mm:id/aep").setText(u"test")  
  50. vc.sleep(_s)  
  51. vc.dump(window=-1)  

在相同窗口環境下執行該腳本就可以自動重復上述操作。

四、參考資料

 

說明:該文章為鯤之鵬(http://www.site-digger.com)原創文章 ,您除了可以發表評論外,還可以轉載到別的網站,但是請保留源地址,謝謝!!(尊重他人勞動,我們共同努力)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM