Python實現(xiàn)過濾單個Android程序日志腳本分享
在Android軟件開發(fā)中,增加日志的作用很重要,便于我們了解程序的執(zhí)行情況和數(shù)據(jù)。Eclipse開發(fā)工具會提供了可視化的工具,但是還是感覺終端效率會高一些,于是自己寫了一個python的腳本來通過包名來過濾某一程序的日志。
原理
通過包名得到對應(yīng)的進程ID(可能多個),然后使用adb logcat 過濾進程ID即可得到對應(yīng)程序的日志。
源碼
#!/usr/bin/env python
#coding:utf-8
#This script is aimed to grep logs by application(User should input a packageName and then we look up for the process ids then separate logs by process ids).
import os
import sys
packageName=str(sys.argv[1])
command = "adb shell ps | grep %s | awk '{print $2}'"%(packageName)
p = os.popen(command)
##for some applications,there are multiple processes,so we should get all the process id
pid = p.readline().strip()
filters = pid
while(pid != ""):
pid = p.readline().strip()
if (pid != ''):
filters = filters + "|" + pid
#print 'command = %s;filters=%s'%(command, filters)
if (filters != '') :
cmd = 'adb logcat | grep --color=always -E "%s" '%(filters)
os.system(cmd)
使用方法
python logcatPkg.py com.mx.browser
最新代碼
#!/usr/bin/env python
#coding:utf-8
#This script is aimed to grep logs by application(User should input a packageName and then we look up for the process ids then separate logs by process ids).
import os
import sys
packageName=str(sys.argv[1])
command = "adb shell ps | grep %s | awk '{print $2}'"%(packageName)
p = os.popen(command)
##for some applications,there are multiple processes,so we should get all the process id
pid = p.readline().strip()
filters = pid
while(pid != ""):
pid = p.readline().strip()
if (pid != ''):
filters = filters + "|" + pid
#print 'command = %s;filters=%s'%(command, filters)
if (filters != '') :
cmd = 'adb logcat | grep --color=always -E "%s" '%(filters)
os.system(cmd)
不足
當腳本執(zhí)行后,Android程序如果關(guān)閉或者重新啟動,導(dǎo)致進程ID變化,無法自動繼續(xù)輸出日志,只能再次執(zhí)行此腳本。
- 通過Python 獲取Android設(shè)備信息的輕量級框架
- 基于Python的Android圖形解鎖程序詳解
- python獲取android設(shè)備的GPS信息腳本分享
- Python實現(xiàn)刪除Android工程中的冗余字符串
- python服務(wù)器與android客戶端socket通信實例
- 使用python編寫批量卸載手機中安裝的android應(yīng)用腳本
- 使用python編寫android截屏腳本雙擊運行即可
- python讀取Android permission文件
- 用Python腳本生成Android SALT擾碼的方法
- python搭建服務(wù)器實現(xiàn)兩個Android客戶端間收發(fā)消息
相關(guān)文章
聯(lián)邦學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)FedAvg算法實現(xiàn)
這篇文章主要為大家介紹了聯(lián)邦學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)FedAvg算法實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05Micropython固件使用Pico刷固件并配置VsCode開發(fā)環(huán)境的方法
這篇文章主要介紹了Micropython固件使用Pico刷固件并配置VsCode開發(fā)環(huán)境的方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-07-07