FileReader读取文件的三种方式

#日常练习

FileReader可以通过一次读取文件中一个字符,一次读取一个字符数组或使用缓冲区这三种方式来读取文件

备注:使用缓冲区的方式的内部实现是借助数组完成

package IO;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;

public class FileReaderDemo {

	public static void main(String[] args) {
		// 读取文件的方式一:逐个字符来读取文本文件
		FileReader fr = null;
		try {
			fr = new FileReader("Demo.txt");

			int ch = fr.read();
			while (ch != -1) {
				System.out.print((char) ch);
				ch = fr.read();
			}
			System.out.println();
		} catch (IOException e) {
			System.out.println("异常:" + e.toString());
		} finally {
			try {
				if (fr != null)
					fr.close();
			} catch (IOException e) {
				System.out.println("异常:" + e.toString());
			}
		}
		
		//读取文件方式二:使用数组来读取文本文件
		FileReader fr1 = null;
		try {
			fr1 = new FileReader("Demo.txt");
			char [] buf = new char[1024];
			int num = 0;
			while((num = fr1.read(buf))!=-1) {
				System.out.println(new String(buf,0,num));
			}
		}catch(IOException e) {
			System.out.println("异常:" + e.toString());
		}finally {
			try {
			if(fr1!=null)
			fr1.close();
			}catch(IOException e) {
				System.out.println("异常:" + e.toString());
			}
		}
		
		//方法三:用缓冲区读取文本文件
		//通过查源码得知方法三内部实现时是使用数组形式来缓冲字符数据的
		FileReader fr2 = null;
		BufferedReader bufr = null;
		try {
			fr2 = new FileReader("Demo.txt");
			bufr = new BufferedReader(fr2);
			String line = null;
			//BufferedReader提供了按行读取文本文件的方法readLine()
			//readLine()返回行有效数据,不包含换行符,未读取到数据返回null
			while((line = bufr.readLine())!=null) {
				System.out.println(line);	
			}
		}catch(IOException e) {
			System.out.println("异常:" + e.toString());
		}finally {
			try {
			if(bufr!=null)
			bufr.close();
			}catch(IOException e) {
				System.out.println("异常:" + e.toString());
			}
		}
	}

}
2018/02/06晚修改:添加FileReader读取文件的第三种方式。



  • 13
    点赞
  • 83
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: 好的,您想了解如何使用JavaScript中的FileReader对象来读取文件。首先,您需要创建一个FileReader对象,然后使用它的readAsText()方法读取文件内容。以下是一个简单的示例: ```javascript // 创建一个FileReader对象 var reader = new FileReader(); // 读取文件 reader.readAsText(file); // 当读取完成时,执行回调函数 reader.onload = function(event) { var contents = event.target.result; console.log(contents); }; ``` 在这个示例中,我们首先创建一个FileReader对象。然后,我们使用它的readAsText()方法来读取一个文件。该方法接受一个File对象作为参数,该对象代表要读取文件。在这个例子中,我们假设已经有一个名为file的File对象。 当读取完成后,FileReader对象将触发一个load事件。我们可以通过在FileReader对象的onload属性上设置一个回调函数来捕获这个事件。在回调函数中,我们可以通过调用event.target.result来获取文件的内容。在这个例子中,我们简单地将内容打印到控制台上。 请注意,由于读取文件是异步操作,因此我们需要等待读取完成后才能访问文件的内容。因此,我们将回调函数分配给FileReader对象的onload属性,以便在读取完成时自动调用。 ### 回答2: FileReader 是一种用于读取文件内容的JavaScript 对象。当我们需要读取一个文本文件中的内容时,可以使用FileReader 对象。FileReader 对象提供了一系列的方法和属性,使我们能够以异步的方式读取文件。 要使用FileReader 对象来读取文件,我们需要先创建一个FileReader 实例,然后通过其方法来读取文件。首先,我们需要使用input 元素的type 属性设置为“file”,这样可以让用户选择一个本地的文件。接着,我们在JavaScript中获取到选择的文件对象,并使用FileReader 实例的readAsText() 方法来读取文件内容。readAsText() 方法的参数可以指定文件编码类型,一般情况下我们可以使用默认的UTF-8 编码。 在读取文件内容的过程中,FileReader 对象会触发onload 事件,我们可以通过监听这个事件来获取到文件内容。在onload 事件的回调函数中,我们可以通过FileReader 实例的result 属性获取到文件的内容。可以通过调用FileReader 实例的readAsDataURL() 方法来将读取到的文件内容转换为数据URL,然后可以将这个URL 用于显示文件的预览或者动态加载文件。 总结来说,FileReader 提供了一种方便的方式读取文本文件的内容。通过其方法和事件,我们能够以异步的方式读取文件内容,并可以对文件进行一系列的操作。使用FileReader 可以给我们的开发带来很大的便利,特别是在需要加载本地文件内容的场景下。 ### 回答3: FileReader是一个内置对象,可以用来读取文件内容。它提供了多种方法来读取不同类型的文件,如文本文件、图片文件等。使用FileReader对象是一种异步操作,可以通过注册事件监听器来处理读取完成后触发的事件。 首先,我们需要使用FileReader的构造函数创建一个实例,然后使用其中的方法来读取文件。常见的方法有readAsText()、readAsArrayBuffer()和readAsDataURL()。 readAsText()方法用于读取文本文件,它会将文件内容以字符串的形式返回。使用该方法时,我们需要为FileReader对象的onload事件注册一个监听器,该监听器会在读取完成后触发。在该监听器中,可以通过调用FileReader对象的result属性获取文件内容。 readAsArrayBuffer()方法用于读取二进制文件,如图片或音频文件。它会将文件内容以ArrayBuffer的形式返回。使用该方法时,同样需要为FileReader对象的onload事件注册监听器,然后在监听器中通过FileReader对象的result属性获取文件内容。 readAsDataURL()方法用于读取文件并将其转换为DataURL格式。DataURL是一种将文件内容编码为字符串的方式,可以用于在网页中显示图片。与之前的方法一样,需要注册onload事件监听器来获取文件内容。 总之,FileReader是用于读取文件内容的工具,提供了多种方法来满足不同类型的文件读取需求。读取文件时需要注册监听器,在监听器中获取文件内容并进行后续操作。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值