在Android界面上顯示和獲取Logcat日志輸出的方法
一、首先我們要獲取Logcat中的日志
如何獲取呢?
首先我們要先定義一個String[]數(shù)組,里面的代碼是
//第一個是Logcat ,也就是我們想要獲取的log日志
//第二個是 -s 也就是表示過濾的意思
//第三個就是 我們要過濾的類型 W表示warm ,我們也可以換成 D :debug, I:info,E:error等等
String[] running = new String[]{"logcat","-s","adb logcat *: W"};
當(dāng)我們設(shè)置好之后,我們還需要一個process類,作用通俗來講就是用Java代碼來進行adb命令行操作代碼是:
Process exec = Runtime.getRuntime().exec(running);
通過以上的方法我們就可以獲得和過濾Logcat中的方法。
二、接下來開始使用IO流進行字符操作,把數(shù)據(jù)保存在Android SDCard中
首先:我們定義一個InputStream,
final InputStream is = exec.getInputStream
接下來開啟一個線程,線程中的方法就是通過IO流先讀取Logcat中的數(shù)據(jù),然后再把數(shù)據(jù)通過OutPutStream方法寫入到SDCard中。
new Thread() {
@Override
public void run() {
FileOutputStream os = null;
try {
//新建一個路徑信息
os = new FileOutputStream("/sdcard/Log/Log.txt");
int len = 0;
byte[] buf = new byte[1024];
while (-1 != (len = is.read(buf))) {
os.write(buf, 0, len);
os.flush();
}
} catch (Exception e) {
Log.d("writelog",
"read logcat process failed. message: "
+ e.getMessage());
} finally {
if (null != os) {
try {
os.close();
os = null;
} catch (IOException e) {
// Do nothing
}
}
}
}
}.start();
} catch (Exception e) {
Log.d("writelog",
"open logcat process failed. message: " + e.getMessage());
}
}
當(dāng)我們這個類寫完之后,我們再把權(quán)限添加進去就可以了。
<!-- 讀取Log權(quán)限 --> <uses-permission android:name="android.permission.READ_LOGS" /> <!-- 在SDCard中創(chuàng)建與刪除文件權(quán)限 --> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" /> <!-- 往SDCard寫入數(shù)據(jù)權(quán)限 --> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <!-- 從SDCard讀出數(shù)據(jù)權(quán)限 --> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
添加完權(quán)限,我們運行試試。

然后我們再打開我們的SDCard中的文件目錄:

這樣我們就已經(jīng)獲取到了Logcat中的日志(可以和控制臺的對比一下):

由于我開啟了兩次所以打印出了兩次的log.
三、之后我們先創(chuàng)建頁面,然后在按行讀取Txt文本中的內(nèi)容
首先我們開始編寫XMl視圖文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<LinearLayout
android:layout_width="match_parent"
android:layout_weight="7"
android:orientation="vertical"
>
<ListView
android:id="@+id/ListLog"
android:layout_width="match_parent"
android:layout_height="match_parent"
></ListView>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_weight="1"
android:gravity="center"
android:orientation="horizontal" >
<Button
android:layout_gravity="center"
android:gravity="center"
android:id="@+id/BtnLog"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="清空日志"
/>
</LinearLayout>
</LinearLayout>
編寫完成后,我們開始在MainActivity里面初始化我們的類
private ListView listView;
private Button btn;
listView = (ListView) findViewById(R.id.ListLog);
btn = (Button) findViewById(R.id.BtnLog);
之后,我們開始編寫我們的讀取TXT文件的方法
/**
* 根據(jù)行讀取內(nèi)容
* @return
*/
public List<String> Txt() {
//將讀出來的一行行數(shù)據(jù)使用List存儲
String filePath = "/sdcard/Log.txt";
List newList=new ArrayList<String>();
try {
File file = new File(filePath);
int count = 0;//初始化 key值
if (file.isFile() && file.exists()) {//文件存在
InputStreamReader isr = new InputStreamReader(new FileInputStream(file));
BufferedReader br = new BufferedReader(isr);
String lineTxt = null;
while ((lineTxt = br.readLine()) != null) {
if (!"".equals(lineTxt)) {
String reds = lineTxt.split("\\+")[0]; //java 正則表達式
newList.add(count, reds);
count++;
}
}
isr.close();
br.close();
}else {
Log.e("tag", "can not find file");
}
} catch (Exception e) {
e.printStackTrace();
}
return newList;
}
我們看d的代碼,其實也就是IO讀寫操作
if (file.isFile() && file.exists()) //這一行是判斷是否有文件存在
然后我們用InputStreamReader讀取我們SDCard中的文件;
使用BufferedReader方法讀取我們獲取的字符流;
最后我們用While循環(huán)和正則表達式來把每一行都給放入List中;
最后我們返回List;
InputStreamReader isr = new InputStreamReader(new FileInputStream(file));
BufferedReader br = new BufferedReader(isr);
String lineTxt = null;
while ((lineTxt = br.readLine()) != null) {
if (!"".equals(lineTxt)) {
String reds = lineTxt.split("\\+")[0]; //java 正則表達式
newList.add(count, reds);
count++;
}
}
還有一個XML視圖文件,名稱log_list_item.xml
<TextView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:textColor="#000000" android:gravity="left" android:paddingLeft="20dp" android:textSize="20sp" android:singleLine="true" />
接下來就是把List放入ListView中:
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, R.layout.log_list_item,Txt()); listView.setAdapter(adapter);
好讓我們運行一下看看效果:

好了,我們的顯示日志也已經(jīng)成功了。接下來就是要可以清空日志;
最后、清空日志
如何清空日志呢?
其實非常簡單
/**
* 刪除Log文件
* @param fileName 文件路徑和名稱
*/
public static void delFile(String fileName){
File file = new File(fileName);
if(file.isFile()){
file.delete();
}
file.exists();
}
我們只需要把路徑傳過去,進行判斷,如果有就直接刪除。
然后我們對ListView進行刷新就可以了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android adb logcat 命令查看日志詳細介紹
- Android shell命令行中過濾adb logcat輸出的幾種方法
- Android開發(fā)之在程序中時時獲取logcat日志信息的方法(附demo源碼下載)
- Android Studio使用小技巧:自定義Logcat
- logcat命令使用方法和查看android系統(tǒng)日志緩沖區(qū)內(nèi)容的方法
- android真機調(diào)試時無法顯示logcat信息的解決方法介紹
- Android開發(fā)筆記之:一分鐘學(xué)會使用Logcat調(diào)試程序的詳解
- 如何通過Android Logcat插件分析firebase崩潰問題
相關(guān)文章
android檢測網(wǎng)絡(luò)連接狀態(tài)示例講解
網(wǎng)絡(luò)的時候,并不是每次都能連接到網(wǎng)絡(luò),因此在程序啟動中需要對網(wǎng)絡(luò)的狀態(tài)進行判斷,如果沒有網(wǎng)絡(luò)則提醒用戶進行設(shè)置2014-02-02
android實現(xiàn)緩存圖片等數(shù)據(jù)
本文給大家分享的是Android采用LinkedHashMap自帶的LRU 算法緩存數(shù)據(jù)的方法和示例,有需要的小伙伴可以參考下。2015-07-07
Android startActivityForResult的基本用法詳解
這篇文章主要介紹了Android startActivityForResult的基本用法詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08
react native android6+拍照閃退或重啟的解決方案
android 6+權(quán)限使用的時候需要動態(tài)申請,那么在使用rn的時候要怎么處理拍照權(quán)限問題呢?本文提供的是一攬子rn操作相冊、拍照的解決方案,需要的朋友可以參考下2017-11-11
Android開發(fā)之自帶下載器DownloadManager的使用示例代碼
本篇文章主要介紹了Android開發(fā)之自帶下載器DownloadManager的使用示例代碼,Android自帶的DownloadManager是一個很好的下載文件的工具,有興趣的可以了解一下。2017-03-03
一文了解Android?ViewModelScope?如何自動取消協(xié)程
這篇文章主要介紹了一文了解Android?ViewModelScope?如何自動取消協(xié)程,文章圍繞主題站展開詳細的內(nèi)容介紹,具有一定參考價值,感興趣的小伙伴可以參考一下2022-07-07

