JAVA输出日志到txt中

方法一:通过log4j来实现

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;

public class LogException {
    /**
     * @将错误信息输入到txt中
     * @param path
     * @throws IOException
     */
    public void writeLog(String path,String content) throws IOException{
 
        File F=new File(path);
        //如果文件不存在,就动态创建文件
        if(!F.exists()){
            F.createNewFile();
        }
        FileWriter fw=null;
        String writeDate="时间:"+this.getNowDate()+"---"+"error:"+content;
        try {
            //设置为:True,表示写入的时候追加数据
            fw=new FileWriter(F, true);
            fw.write(writeDate+"\r\n");
        } catch (IOException e) {
            e.printStackTrace();
        }finally{
            if(fw!=null){
                fw.close();
            }
        }
 
    }
    /**
     * @获取系统当前时间
     * @return
     */
    public  String getNowDate(){
        Calendar D=Calendar.getInstance();
        int y=0;
        int m=0;
        int d=0;
        y=D.get(Calendar.YEAR);
        m=D.get(Calendar.MONTH)+1;
        d=D.get(Calendar.DAY_OF_MONTH);
        String nowDate=String.valueOf(y)+"-"+String.valueOf(m)+"-"+String.valueOf(d);
        return nowDate;
    }

    //测试方法

    public static void main(String[] args) throws IOException {

        LogException le=new LogException();
        try {
            le.writeLog("G:/ticket.txt", request.toString());
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

 

方法二:使用定向输出流

 

public class RedirectOutputStream {
    public static void main(String[] args) {
        try {
            PrintStream out = System.out;// 保存原输出流
            PrintStream ps=new PrintStream(“E:/log.txt”);// 创建文件输出流1
            PrintStream ps2=new PrintStream(“./log.txt”);// 创建文件输出流2

            System.setOut(ps);// 设置使用新的输出流
            System.out.println("使用新的输出流将log输出到 E:/log.txt");

            System.setOut(ps2);// 设置使用新的输出流
            System.out.println("使用新的输出流将log输出到 ./log.txt");

            System.setOut(out);// 恢复原有输出流
            System.out.println("程序运行完毕,恢复为原输出流。");
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
    }

}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蜡筆尛賢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值