java如何java将数组写入文件件

全面了解java byte数组与文件读写
投稿:jingxian
字体:[ ] 类型:转载 时间:
下面小编就为大家带来一篇全面了解java byte数组与文件读写。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
全面了解java byte数组与文件读写
import java.io.ByteArrayOutputS
import java.io.F
import java.io.FileInputS
import java.io.FileOutputS
import java.io.IOE
public class FileHelper {
&span style="white-space:pre"&
&/span&//第一种获取文件内容方式
public byte[] getContent(String filePath) throws IOException {
File file = new File(filePath);
long fileSize = file.length();
if (fileSize & Integer.MAX_VALUE) {
System.out.println("file too big...");
FileInputStream fi = new FileInputStream(file);
byte[] buffer = new byte[(int) fileSize];
int offset = 0;
int numRead = 0;
while (offset & buffer.length
&& (numRead = fi.read(buffer, offset, buffer.length - offset)) &= 0) {
offset += numR
// 确保所有数据均被读取
if (offset != buffer.length) {
throw new IOException("Could not completely read file "
+ file.getName());
fi.close();
//第二种获取文件内容方式
public byte[] getContent2(String filePath) throws IOException
FileInputStream in=new FileInputStream(filePath);
ByteArrayOutputStream out=new ByteArrayOutputStream(1024);
System.out.println("bytes available:"+in.available());
byte[] temp=new byte[1024];
int size=0;
while((size=in.read(temp))!=-1)
out.write(temp,0,size);
in.close();
byte[] bytes=out.toByteArray();
System.out.println("bytes size got is:"+bytes.length);
//将byte数组写入文件
public void createFile(String path, byte[] content) throws IOException {
FileOutputStream fos = new FileOutputStream(path);
fos.write(content);
fos.close();
以上这篇全面了解java byte数组与文件读写就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具java 后台 Excel 文件生成后转化为字节流 - 心静如水,人淡如菊! - ITeye技术网站
博客分类:
java 后台 Excel 文件生成后转化为字节流
java excel 使用 poi组件, HSSFWorkbook workBook = new HSSFWorkbook();
对于workBook生成字节流,很容易发现有个workBook .getBytes(),但是,是不可用的,下载以后打不开,
如果下载,正确的写法为
workBook.write(response.getOutputStream());
如果转化为字节流:
ByteArrayOutputStream os = new ByteArrayOutputStream();
workBook.write(os);
ByteArray bytes = os.toByteArray();
String fileName = "xxx.xls";
response.reset();
response.setContentType("application/charset=utf-8");
response.setHeader("Content-disposition", "filename= "+ fileName);
response.getOutputStream().write(bytes.getRawBytes());
response.getOutputStream().flush();
response.getOutputStream().close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
上代码经过验证可行。
java excel 使用 poi组件, HSSFWorkbook workBook = new HSSFWorkbook();
对于workBook生成字节流,很容易发现有个workBook .getBytes(),但是,是不可用的,下载以后打不开,
如果下载,正确的写法为
workBook.write(response.getOutputStream());
如果转化为字节流:
ByteArrayOutputStream os = new ByteArrayOutputStream();
workBook.write(os);
ByteArray bytes = os.toByteArray();
String fileName = "xxx.xls";
runData.getResponse().reset();
runData.getResponse().setContentType("application/charset=utf-8");
runData.getResponse().setHeader("Content-disposition", "filename= "+ fileName);
runData.getResponse().getOutputStream().write(bytes.getRawBytes());
runData.getResponse().getOutputStream().flush();
runData.getResponse().getOutputStream().close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
:ByteArrayOutputStream os = new ByteArrayOutputStream();
hssfWorkbook.write(os);
return new FileTransfer(new String("XXXX.xls".getBytes(),"iso8859-1"),
"application/ms-excel", os.toByteArray());
catch (IOException e)
e.printStackTrace();
这里,我们使用了ByteArrayOutputStream和ByteArrayInputStream类...处理的思想是,将HSSFWorkbook 写入ByteArrayOutputStream.然后用ByteArrayOutputStream来转换为字节流..然后再将字节流转换为ByteArrayInputStream ..至此,我们就在内存中将excel转换成了输入流..
ByteArrayOutputStream os = new ByteArrayOutputStream();
wb.write(os);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
byte[] b = os.toByteArray();
ByteArrayInputStream in = new ByteArrayInputStream(b);
全部的代码太多,不贴上来了..相信大家都愿意用这个办法..因为使用之前说的那个产生随机文件名的办法.要繁琐的多...
首先,我们必须明确我们所要实现的功能.我们在之前已经使用SHHF完成了excel的生成,现在的工作是将这个excel转换成输入流提供给struts2以实现下载...也就是说我们是要转换成输入流....
明确了目标以后,我们将开始设计...我们的思路是,先创建一个输出流,将这个excel写入到输出流里面,然后再通过这个输出流来得到我们所需要的输入流...这里我们尝试了两张办法.第一种,就是使用临时文件的办法.我们创建的输出流先将内容写入到临时文件里面,然后我们从临时文件里读取输入流.这个办法我们用到的是FileOutputStream 和FileInputStream.
但是临时文件的问题让程序变得异常复杂,所以我们的目标改成在内存中完成对excel到输入流的转换.所以我们用到了ByteArrayInputStream 和ByteArrayOutputStream .其实就是这么简单..
最后附上从Excel模板获得需要导出的EXCEL文件的输入流方法。
public InputStream getExcelISForAs(List&Object& list) throws Exception {
InputStream excelStream = null;
FileInputStream fis = new FileInputStream(templatePath + "/template.xls");
HSSFWorkbook wb = new HSSFWorkbook(new POIFSFileSystem(fis));
fis.close();
generateExcelForAs(list, wb);//填充EXCEL内容方法
ByteArrayOutputStream out = new ByteArrayOutputStream();
HSSFWorkbook hssWb = (HSSFWorkbook)
hssWb.write(out);
excelStream = new ByteArrayInputStream(out.toByteArray());
out.close();
return excelS
浏览 16179
齐晓威_518
浏览: 269665 次
来自: 郑州
国内的pageoffice插件也可以生成excel。也可以用流 ...
你好,请问这个还有源码吗?我刚开始接触这个,想要源码学习一下. ...
这是增加删除列,,,,
很明显这是增加删除行java数组序列化后存储到文件,读出来的数据和写入的不一样 - ITeye问答
**************************************************
import java.io.S
public class Map implements Serializable{
private byte[][]
public byte[][] getMap() {
public void setMap(byte[][] map) {
this.map =
}
}
********************************************************
import java.io.FileInputS
import java.io.FileNotFoundE
import java.io.FileOutputS
import java.io.IOE
import java.io.ObjectInputS
import java.io.ObjectOutputS
import java.util.A
import java.util.V
public class ControlMap {
Vector&Map& mapVector=new Vector&Map&();
public void writeMap(byte myMap[][])
readMap();
ObjectOutputS
oos = new ObjectOutputStream(new FileOutputStream("map.map"));
Map map=new Map();
map.setMap(myMap);
mapVector.add(map);
oos.writeObject(mapVector);
oos.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
public void readMap()
ObjectInputStream ois=new ObjectInputStream(new FileInputStream("map.map"));
mapVector=(Vector)(ois.readObject());
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
public String toString()
readMap();
int size=mapVector.size();
String temp="";
for(int i=0;i&i++)
temp+="第"+(i+1)+"张地图:\n";
Map map=mapVector.get(i);
byte mapData[][]=map.getMap();
for(int j=0;j&mapData.j++)
temp+=Arrays.toString(mapData[i])+"\n";
temp+="\n";
}
***************************************************************************************
public class Test {
public static void main(String[] args) {
ControlMap control=new ControlMap();
byte [][] myMap={
{3,7,5,2,4,6,8},
{3,7,5,2,4,6,8},
{3,7,5,2,4,6,8},
{3,7,5,2,4,6,8},
{3,7,5,2,4,6,8},
{3,7,5,2,4,6,8},
{3,7,5,2,4,6,8}
control.writeMap(myMap);
System.out.println(control);
}
*******************************************************************************
下载次数: 5
采纳的答案
public String toString()
readMap();
int size=mapVector.size();
String temp="";
for(int i=0;i&i++)
temp+="第"+(i+1)+"张地图:\n";
Map map=mapVector.get(i);
byte mapData[][]=map.getMap();
for(int j=0;j&mapData.j++)
temp+=Arrays.toString(mapData[i])+"\n";
temp+="\n";
这个是不是该改成j 。大哥。呵呵
public String toString()
readMap();
int size=mapVector.size();
String temp="";
for(int i=0;i&i++)
temp+="第"+(i+1)+"张地图:\n";
Map map=mapVector.get(i);
byte mapData[][]=map.getMap();
for(int j=0;j&mapData.j++)
temp+=Arrays.toString(mapData[i])+"\n";
temp+="\n";
这个是不是该改成j 。大哥。呵呵
已解决问题
未解决问题java使用 DataOutputStream向文件中写入字符 - 为程序员服务
为程序员服务
java使用 DataOutputStream向文件中写入字符
package cn.outofmemory.snippets.
import java.io.DataOutputS
import java.io.FileNotFoundE
import java.io.FileOutputS
import java.io.IOE
public class WriteCharToFileWithDataOutputStream {
public static void main(String[] args) {
String filename = &output.txt&;
FileOutputStream fos =
DataOutputStream dos =
fos = new FileOutputStream(filename);
dos = new DataOutputStream(fos);
char c = 'A';
dos.writeChar(c);
catch (FileNotFoundException fnfe) {
System.out.println(&File not found& + fnfe);
catch (IOException ioe) {
System.out.println(&Error while writing to file& + ioe);
if (dos != null) {
dos.close();
if (fos != null) {
fos.close();
catch (Exception e) {
System.out.println(&Error while closing streams& + e);
您可能的代码
相关聚客文章
相关专栏文章

我要回帖

更多关于 java 文件数组 的文章

 

随机推荐