概述
本工具类参考博客: 将logcat写进SD卡(能追加)并按文件大小进行删除_晔子的小跟班成长记录-CSDN博客
将logcat写进SD卡(能追加)并按文件大小进行删除_晔子的小跟班成长记录-CSDN博客有参考他人博客,有篇博客是根据文件日期进行删除的 原文地址http://xiangqianppp-163-com.iteye.com/blog/1417743将日志记录在文件中并每天生成一个日志文件 原文地址:http://easion-zms.iteye.com/blog/981568Android - 文件读写操作 总结 原文地址:http://blog.csdn.net/zhttps://blog.csdn.net/tiamolili/article/details/8818637
L.java 对Log日志进行管理,打印日志并保持到手机sd卡的txt文件中,方便查看接口数据,或者埋点数据,定位问题
package pc.wlt.com.superlibrary.utils; import android.util.Log; import java.io.BufferedWriter; import java.io.File; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; /** * Log统一管理类 */ public class L { private L() { /* cannot be instantiated */ throw new UnsupportedOperationException("cannot be instantiated"); } // 下面是传入自定义tag的函数 // public static boolean isDebug = BuildConfig.DEBUG;// 是否需要打印bug,可以在application的onCreate函数里面初始化 debug模式自动打印 public static boolean isDebug = true;// 是否需要打印bug,可以在application的onCreate函数里面初始化 debug模式自动打印 private static final String TAG = "pas"; private static Boolean LOG_WRITE_TO_FILE = true;// 日志写入文件开关 private static char LOG_TYPE = 'v';// 输入日志类型,w代表只输出告警信息等,v代表输出所有信息 private static String LOG_PATH_SDCARD_DIR = "/sdcard/"+"Log";// 日志文件在sdcard中的路径 private static int SDCARD_LOG_FILE_SAVE_DAYS = 0;// sd卡中日志文件的最多保存天数 private static String LOG_FILE_NAME = "Log.txt";// 本类输出的日志文件名称 private static SimpleDateFormat LogFormat = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss");// 日志的输出格式 private static SimpleDateFormat logfile = new SimpleDateFormat("yyyy-MM-dd");// 日志文件格式 // 下面四个是默认tag的函数 public static void i(String msg) { if (isDebug) i(TAG, msg); } public static void d(String msg) { if (isDebug) d(TAG, msg); } public static void e(String msg) { if (isDebug) e(TAG, msg); } public static void v(String msg) { if (isDebug) v(TAG, msg); } public static void w(String tag, Object msg) { // 警告信息 log(tag, msg.toString(), 'w'); } public static void e(String tag, Object msg) { // 错误信息 log(tag, msg.toString(), 'e'); } public static void d(String tag, Object msg) {// 调试信息 log(tag, msg.toString(), 'd'); } public static void i(String tag, Object msg) {// log(tag, msg.toString(), 'i'); } public static void v(String tag, Object msg) { log(tag, msg.toString(), 'v'); } public static void w(String tag, String text) { log(tag, text, 'w'); } public static void e(String tag, String text) { log(tag, text, 'e'); } public static void d(String tag, String text) { log(tag, text, 'd'); } public static void i(String tag, String text) { log(tag, text, 'i'); } public static void v(String tag, String text) { log(tag, text, 'v'); } /** * 根据tag, msg和等级,输出日志 * * @param tag * @param msg * @param level * @return void * @since v 1.0 */ private static void log(String tag, String msg, char level) { if (isDebug) { if ('e' == level && ('e' == LOG_TYPE || 'v' == LOG_TYPE)) { // 输出错误信息 Log.e(tag, msg); } else if ('w' == level && ('w' == LOG_TYPE || 'v' == LOG_TYPE)) { Log.w(tag, msg); } else if ('d' == level && ('d' == LOG_TYPE || 'v' == LOG_TYPE)) { Log.d(tag, msg); } else if ('i' == level && ('d' == LOG_TYPE || 'v' == LOG_TYPE)) { Log.i(tag, msg); } else { Log.v(tag, msg); } if (LOG_WRITE_TO_FILE) writeLogToFile(String.valueOf(level), tag, msg); } } /** * 打开日志文件并写入日志 * * @return **/ private static void writeLogToFile(String mylogtype, String tag, String text) {// 新建或打开日志文件 Date nowtime = new Date(); String needWriteFiel = logfile.format(nowtime); String needWriteMessage = LogFormat.format(nowtime) + " " + mylogtype + " " + tag + " " + text; File fileDir=new File(LOG_PATH_SDCARD_DIR); if (!fileDir.exists()){ fileDir.mkdir(); } File file = new File(fileDir, needWriteFiel + LOG_FILE_NAME); try { FileWriter filerWriter = new FileWriter(file, true);//后面这个参数代表是不是要接上文件中原来的数据,不进行覆盖 BufferedWriter bufWriter = new BufferedWriter(filerWriter); bufWriter.write(needWriteMessage); bufWriter.newLine(); bufWriter.close(); filerWriter.close(); } catch (IOException e) { e.printStackTrace(); } // inPut(file); } /** * 删除制定的日志文件 */ public static void delFile() {// 删除日志文件 String needDelFiel = logfile.format(getDateBefore()); File file = new File(LOG_PATH_SDCARD_DIR, needDelFiel + LOG_FILE_NAME); if (file.exists()) { file.delete(); } } /** * 得到现在时间前的几天日期,用来得到需要删除的日志文件名 */ private static Date getDateBefore() { Date nowtime = new Date(); Calendar now = Calendar.getInstance(); now.setTime(nowtime); now.set(Calendar.DATE, now.get(Calendar.DATE) - SDCARD_LOG_FILE_SAVE_DAYS); return now.getTime(); } /** * 读取 * * @return */ public static void inPut(File fileName) { FileReader reader = null; char[] buf = new char[1024]; int len = 0; try { reader = new FileReader(fileName);//fileName文件路径 while ((len = reader.read(buf)) != -1) { L.e("===========" + new String(buf, 0, len)); } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { try { reader.close(); } catch (IOException e) { e.printStackTrace(); } } } }
用法:
@Override protected void onRestart() { super.onRestart(); L.d(TAG,"onRestart"); } @Override protected void onStart() { super.onStart(); L.d(TAG,"onStart"); } @Override protected void onResume() { super.onResume(); L.d(TAG,"onResume"); } @Override protected void onPause() { super.onPause(); L.d(TAG,"onPause"); } @Override protected void onStop() { super.onStop(); L.d(TAG,"onStop"); }
源码地址:WUtils/L.java at master · qingfengwlt/WUtils (github.com)
最后
以上就是忧郁小伙为你收集整理的Log日志工具类(可保存到手机sd本地txt中)的全部内容,希望文章能够帮你解决Log日志工具类(可保存到手机sd本地txt中)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复