亲宝软件园·资讯

展开

ByteArrayOutputStream将数据写入本地文件

Debug卷心菜 人气:0

ByteArrayOutputStream将数据写入本地文件

在一个项目中做一次性校验部分,需要将校验后数据写入表格后上传。巧的是,服务器Down了。作为一个新手实习生菜鸟,为了测试自己的代码和输出结果有没有毛病,在大神同事的指点下选择了先将表格输出到本地

于是在百度疯狂搜索“输出流”、“输出文件到本地”、“文件流”等,经过多方搜集和探查以及加工,最后加上了一小段代码

//测试-将表格导入本地文件
        FileOutputStream fileOutputStream = null;
        try {
            fileOutputStream = new FileOutputStream("C:\\Users\\Administrator.DESKTOP-SFAEOA8\\Desktop\\consistencyCheckCommodityRuleTemplate.xlsx");
            fileOutputStream.write(byteArrayOutputStream.toByteArray());
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

以下是上传Excel的部分代码。将最后的上传文件到dfs的方法注掉,以在准备好的文件 C:\\Users\\Administrator.DESKTOP-SFAEOA8\\Desktop\\consistencyCheckCommodityRuleTemplate.xlsx 中输出需要的结果

public void uploadExcel() {
 
        //获取校验数据
        List<DTO> consistencyCheck = getConsistencyCheck();
 
        //创建模板信息
        DataModel dataModel = setDataModel();
        ......(此处省略一万字)
 
        //创建ExcelData
        ExcelData excelData = setExcelData();
        ......(此处也省略一万字)
 
        //创建日志数据
        ConsistencyCheckLog consistencyCheckLog = setConsistencyCheckLog();
        ......(此处又省略一万字)
 
        //创建excel
        ByteArrayOutputStream  byteArrayOutputStream = createExcel(dataModel, excelData);
 
        //测试-将表格导入本地文件
        FileOutputStream fileOutputStream = null;
        try {
            fileOutputStream = new FileOutputStream("C:\\Users\\Administrator.DESKTOP-SFAEOA8\\Desktop\\consistencyCheckCommodityRuleTemplate.xlsx");
            fileOutputStream.write(byteArrayOutputStream.toByteArray());
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
 
        //上传excel(无法上传 先注掉好了)
        //uploadFileToDfs(consistencyCheckLog, byteArrayOutputStream);
    }

这样就OK了,只添加了测试的部分,得到数据后也是放下了这颗菜心

那来了解一下ByteArrayOutPutStream吧

序号 方法描述
1 public void reset() 将此字节数组输出流的 count 字段重置为零,从而丢弃输出流中目前已累积的所有数据输出。
2 public byte[] toByteArray() 创建一个新分配的字节数组。数组的大小和当前输出流的大小,内容是当前输出流的拷贝。
3 public String toString() 将缓冲区的内容转换为字符串,根据平台的默认字符编码将字节转换成字符。
4 public void write(int w) 将指定的字节写入此字节数组输出流。
5 public void write(byte []b, int off, int len) 将指定字节数组中从偏移量 off 开始的 len 个字节写入此字节数组输出流。
6 public void writeTo(OutputStream outSt) 将此字节数组输出流的全部内容写入到指定的输出流参数中。

在表格输出时

Java输出流FileOutputStream也发挥了至关重要的作用

使用FileOutputStream写入文件的过程同使用FileInputStream过程相同,都是先用File类打开本地文件,实例化输入输出流,然后调用流的读写方法读取或写入数据,最后关闭流。

FileOutputStream的写入方法

FileOutputStream类提供了多种文件写入方法,可以单独写一个字节到文件,也可以写一个byte数组到文件,也可以取byte数组的部分数据写入到文件。

把读取的结果写入到ByteArrayOutputStream

 // 把读取的结果写入到ByteByteArrayOutputStream
 public static void main(String[] args) throws IOException {
  // TODO Auto-generated method stub
  String s = "C:\\a.txt";
  int len = 0;
  FileInputStream stream = new FileInputStream(s);
  ByteArrayOutputStream stream2 = new ByteArrayOutputStream();
  byte[] buffer = new byte[5];
  //先读后写,循环读写
  while ((len = stream.read(buffer)) != -1) {
   stream2.write(buffer, 0, len);
  }
  byte[] data = stream2.toByteArray();
  System.out.println(new String(data));
 }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

加载全部内容

相关教程
猜你喜欢
用户评论