Java IO读写文件

       测试代码类好多工作都是跟io有关系:日志的解析,有的时候我们做UI或者接口自动化测试,工具提供的测试报告不能满足我们的需求,这个时候我们就需要自己写测试报告,原理就是基于IO基础知识。字符流只处理文字,而字节流,处理所有东东包括:图片,音频,视频,文字,之所以把字符流单独提取,就是为了提升对于文件的读写效率。

具体案例:

package com.my.io.demo;

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.Date;

public class FileDemo {
	
	public static void main(String[] args) {
		
		writeFile();
		readFile();
		
	}
	
	public static String formatCurrentTime() {
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy_MM_dd_HH_mm_ss");
		Date date = new Date(System.currentTimeMillis());

		return sdf.format(date);
	}
	
	public static void writeFile() {
		File f = new File("d:"+File.separator+"testm10.txt");
		System.out.println(f.getAbsolutePath());
		System.out.println(f.canRead());
		
		String base = System.getProperty("user.dir");
		System.out.println(base);
		
		File path = new File(base+File.separator+"result");
		System.out.println(path);
		
		File logFile = new File(path,formatCurrentTime()+".log");
		System.out.println(logFile);
		
		if(!logFile.exists()) {
			
			if(!path.exists()) {
				path.mkdir();
			}
			
			try {
				
				logFile.createNewFile();
				System.out.println("创建文件成功!");
				
			} catch (IOException e) {
				e.printStackTrace();
			}
		}else {
			System.out.println("文件存在!");
		}
		
		try {
			
			FileWriter fw = new FileWriter(logFile);
			fw.write("Info "+formatCurrentTime()+" info test\r\n");
			Thread.sleep(1000);
			
			fw.write("Debug "+formatCurrentTime()+" debug test\r\n");
			fw.close();
			
		} catch (IOException e) {
			e.printStackTrace(); 
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
	
	public static void readFile() {
		FileReader fr = null;
		try {
			
			fr = new FileReader("D:\\eclipse-workspace\\HelloWorld\\result\\2020_03_12_14_45_30.log");
			int ch = 0;
			while((ch=fr.read()) != -1) {
//				System.out.print(ch); //ch 代表ASCII码表
				System.out.print((char)ch);
			}
			
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}finally {
			try {
				fr.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
			
		}
	}
}

 运行结果:

 

在日志中写入html的格式
一般日志的内容包括:
定义head 和tail
找到需要重复写入日志中的内容,并进行参数化
提供写日志接口
注意tail部分数据的统计设计
日志模块入口的设计,根据不同的文件名后缀,调用不同的类
junit4中测试日志的应用
把测试结果写入测试用例中

package com.my.io.demo;

import java.io.FileWriter;
import java.io.IOException;

public class WriteFileDemo {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		
		FileWriter fw;
		try {
			
			//文件大小的判断
			fw = new FileWriter("d:/demo_io.html",true);
			//fw = new FileWriter("d:/demo_io.html");
		
			fw.write("<html>");
			fw.write("<b>");
			fw.write("2222abc55555");
			fw.write("</b>");
			fw.write("def");
			fw.write("</html>");
			
			fw.close();
			
		} catch (IOException e) {
			e.printStackTrace();
		}

	}	
	
}

 运行结果:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值