Android 把Log日志文件写入到本地txt文件中

package topteam.com.myproject.utin;

import android.os.Environment;
import android.util.Log;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.OutputStreamWriter;

public class LogUtil {

    private static final int LEV_D = 1;
    private static final int LEV_W = 2;

    public static void d(String tag, String msg) {
        if (LEV_D == 1) {
            Log.d(tag, msg);
        }
    }

    /**
     * 为避免产生大量垃圾日志文件,引入一个常量来决定是否需要打印日志
     * @param msg 打印的日志消息
     */
    public static void writerlog(String msg) {
        if (LEV_W == 2) {
            //保存到的文件路径
            final String filePath = Environment.getExternalStorageDirectory().getAbsolutePath();
            FileWriter fw = null;
            BufferedWriter bw = null;

            try {
                //创建文件夹
                File dir = new File(filePath, "fpad");
                if (!dir.exists()) {
                    dir.mkdir();
                }
                //创建文件
                File file = new File(dir, "mesdebug.txt");
                if (!file.exists()) {
                    file.createNewFile();
                }
                //写入日志文件
                fw = new FileWriter(file, true);
                bw = new BufferedWriter(fw);
                bw.write(App.getSystime("yyyy-MM-dd HH:mm:ss") + "   " + msg + "\n");
                bw.close();
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                if (bw != null) {
                    try {
                        bw.close();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }

            }
        }


    }
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android ,我们可以使用日志框架 Logcat 来输出日志信息,但是 Logcat 的输出信息只能在控制台查看,无法保存到文件。如果需要将日志信息保存到文件,可以通过以下步骤实现按天为单位保存: 1. 创建保存日志信息的目录 在 Android ,我们可以使用 `Context.getFilesDir()` 方法获取应用程序的私有目录,然后在这个目录下创建一个名为“log”的目录,用于保存日志信息。 ```java File logDir = new File(getFilesDir(), "log"); if (!logDir.exists()) { logDir.mkdir(); } ``` 2. 定义日志文件名称 在保存日志信息时,需要为每个日志文件定义一个唯一的名称,可以根据当前日期来生成日志文件名称。可以使用 `SimpleDateFormat` 类来格式化日期。 ```java SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()); String logFileName = dateFormat.format(new Date()) + ".log"; ``` 3. 将日志信息写入文件输出日志信息时,可以将日志信息写入到指定的日志文件。可以使用 `PrintWriter` 类来实现写入文件操作。 ```java File logFile = new File(logDir, logFileName); PrintWriter writer = new PrintWriter(new FileWriter(logFile, true)); writer.println("[" + dateFormat.format(new Date()) + "] " + message); writer.flush(); writer.close(); ``` 完整的代码如下: ```java public static void log(String message) { try { SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()); String logFileName = dateFormat.format(new Date()) + ".log"; File logDir = new File(getFilesDir(), "log"); if (!logDir.exists()) { logDir.mkdir(); } File logFile = new File(logDir, logFileName); PrintWriter writer = new PrintWriter(new FileWriter(logFile, true)); writer.println("[" + dateFormat.format(new Date()) + "] " + message); writer.flush(); writer.close(); } catch (IOException e) { e.printStackTrace(); } } ``` 在应用程序调用 `log()` 方法输出日志信息时,将会按天为单位保存到指定的日志文件
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值