app开发者平台在数字化时代的重要性与发展趋势解析
1851
2022-11-16
使用ByteArrayOutputStream实现将数据写入本地文件
目录ByteArrayOutputStream将数据写入本地文件那来了解一下ByteArrayOutPutStream吧在表格输出时FileOutputStream的写入vGjYC方法把读取的结果写入到ByteArrayOutputStream
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
//创建模板信息
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吧
ByteArrayOutputStream类是在创建它的实例时,程序内部创建一个byte型别数组的缓冲区,然后利ByteArrayOutputStream和ByteArrayInputStream的实例向数组中写入或读出byte型数据
字节数组输出流在内存中创建一个字节数组缓冲区,所有发送到输出流的数据保存在该字节数组缓冲区
成功创建字节数组输出流对象后,可以参见以下列表中的方法,对流进行写操作或其他操作
序号
方法描述
1
public void reset() 将此字节数组输出流的 count 字段重置为零,从而丢弃输出流中目前已累积的所有数据输出。
2
public byte[] toByteArray() 创建一个新分配的字节数组。数组的大小和当前输出流的大小,vGjYC内容是当前输出流的拷贝。
3
public String toShttp://tring() 将缓冲区的内容转换为字符串,根据平台的默认字符编码将字节转换成字符。
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
FileOutputStream 可以把数据写到文件中去
ByteArrayOutputStream 可以把其他地方的读入的数据写到这里面,最后获取数据所有的 byte[],相当于可以把数据全部读到内存中来.
// 把读取的结果写入到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));
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~