InputStream,OutputStream的用法以及相应的案例

1. 文件系统的操作:File类。

2. 文件内容的操作:Stream流。

字符流:IntputStream , OutputStream。

字节流:read , write。


InputStream,OutputStream


InputStream和OutputStream都不能被实例化,他们都是抽象类,在Java中提供了他们的一些子类,可以直接实例,他们分别为,FileInputStream和FileOutputStream。

在实例他们需要参数,1)填写字符转(表示文件的路径)2)填写File对象。

1. InputStream

  在实例完就可以读取文件了,调用read方法来读取文件。一次只读一个字节,返回值为一个整型。

在read封装的方法中,读完一个文件的时候正好是一个字节。

如图:

还有这里的放回值问什么是int?因为当读完的时候,会返回一个-1 , 因为根据一个字节的范围,0-255,最后一个为-1。

如图:

写一个代码,读取D盘上的文件。

如代码:

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;

public class Demo2 {
    public static void main(String[] args) throws IOException {
        InputStream inputStream = new FileInputStream("d:/test.txt");
        while(true){
            int b = inputStream.read();
            if(b == -1){
                break;

            }
            System.out.printf("0x%x " , b);
        }
    }
}

运行结果:


2.OutputStream

关于OutputStream,是调用write方法来写。

如图:

上代码:

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;

public class Demo3 {
    public static void main(String[] args) {
        try(OutputStream outputStream = new FileOutputStream("d:/test.txt" , true)) {
            outputStream.write(97);
            outputStream.write(98);
            outputStream.write(99);
            outputStream.write(100);

        }
        catch (IOException e){
            e.printStackTrace();
        }
    }
}

上面的true表示的是,是否要追加写原来存在的文件。

我这里写的还是上面图片上的。

如运行结果:

代表成功了。

如图:

我们的test文件也写成功了。


代码案例,复制文件


这里我们直接上代码。

需要注意一点就是在流对象创建好后,需要关闭,可以 .close ,也可以try里面套用,直接就行了。

代码:

import java.io.*;
import java.util.Scanner;

public class Demo6 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入要复制的文件路径:");
        String srcPath = sc.next();
        System.out.println("请输入要复制文件的目标路径:");
        String destPath = sc.next();

        //验证路径是否合法
        File srcFlie = new File(srcPath);
        if(!srcFlie.isFile()){
            System.out.println("不是文件,请重新输入:");
            return;
        }
        File destFile = new File(destPath);
        if(!destFile.getParentFile().isDirectory()){
            System.out.println("复制文件的目标路径非法,请重新输入:");
            return;
        }

        try(InputStream inputStream = new FileInputStream(srcFlie);
        OutputStream outputStream = new FileOutputStream(destFile)){
            while(true){
                byte[] bytes = new byte[1024];
                int n = inputStream.read(bytes);
                if(n == -1){
                    break;
                }
                outputStream.write(bytes , 0 , n);
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EasyExcel 是一个基于 Java 的简单、省内存的操作 Excel 的开源项目,支持读取、写入各种格式的 Excel 文件,并且具有高效、易用、可扩展等特点。下面是一个 EasyExcel 导入导出案例实现。 1. 导入Excel文件 我们假设要导入一个 Excel 文件,包含姓名、年龄、地址三列数据,其中第一行为表头,从第二行开始是实际数据。 首先,我们需要定义一个实体类,用于保存 Excel 中的每一行数据: ``` public class Person { private String name; private int age; private String address; // 省略getters和setters } ``` 然后,我们可以使用 EasyExcel 提供的 `@ExcelProperty` 注解将 Excel 中的每一列映射到实体类的属性上: ``` public class Person { @ExcelProperty(index = 0) private String name; @ExcelProperty(index = 1) private int age; @ExcelProperty(index = 2) private String address; // 省略getters和setters } ``` 接下来,我们需要定义一个监听器类,用于读取 Excel 文件并将数据转换成实体类: ``` public class PersonListener extends AnalysisEventListener<Person> { private List<Person> dataList = new ArrayList<>(); @Override public void invoke(Person person, AnalysisContext analysisContext) { dataList.add(person); } @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { // 数据读取完毕后的操作 } public List<Person> getDataList() { return dataList; } } ``` 最后,我们可以使用 EasyExcel 提供的 `EasyExcel.read()` 方法来读取 Excel 文件: ``` String fileName = "person.xlsx"; InputStream inputStream = new FileInputStream(fileName); PersonListener personListener = new PersonListener(); EasyExcel.read(inputStream, Person.class, personListener).sheet().doRead(); List<Person> dataList = personListener.getDataList(); ``` 2. 导出Excel文件 我们假设要导出一个 Excel 文件,包含姓名、年龄、地址三列数据,其中第一行为表头,从第二行开始是实际数据。 首先,我们需要定义一个列表,保存需要导出的数据: ``` List<Person> dataList = new ArrayList<>(); dataList.add(new Person("张三", 25, "上海")); dataList.add(new Person("李四", 30, "北京")); dataList.add(new Person("王五", 35, "广州")); ``` 然后,我们可以使用 EasyExcel 提供的 `@ExcelProperty` 注解将实体类的属性映射到 Excel 中的每一列: ``` public class Person { @ExcelProperty(value = "姓名", index = 0) private String name; @ExcelProperty(value = "年龄", index = 1) private int age; @ExcelProperty(value = "地址", index = 2) private String address; // 省略getters和setters } ``` 接下来,我们需要定义一个写出器,用于将数据写入 Excel 文件: ``` public class PersonWriter { public static void write(String fileName, List<Person> dataList) throws IOException { OutputStream outputStream = new FileOutputStream(fileName); ExcelWriter excelWriter = EasyExcel.write(outputStream, Person.class).build(); WriteSheet writeSheet = EasyExcel.writerSheet().build(); excelWriter.write(dataList, writeSheet); excelWriter.finish(); } } ``` 最后,我们可以调用 `PersonWriter.write()` 方法将数据写入 Excel 文件: ``` String fileName = "person.xlsx"; PersonWriter.write(fileName, dataList); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值