java实现excel和txt文件互转
话不多说,请看代码:
importjava.io.*;
importjxl.*;
importjxl.write.*;
//用java将txt数据导入excel
publicclassCreateXLS
{
publicstaticvoidmain(Stringargs[])
{
try
{
//打开文件
WritableWorkbookbook=Workbook.createWorkbook(newFile("测试.xls"));
//生成名为“第一页”的工作表,参数0表示这是第一页
WritableSheetsheet=book.createSheet("第一页",0);
//在Label对象的构造子中指名单元格位置是第一列第一行(0,0)
//以及单元格内容为test
Labellabel=newLabel(0,0,"test");
//将定义好的单元格添加到工作表中
sheet.addCell(label);
/*生成一个保存数字的单元格
必须使用Number的完整包路径,否则有语法歧义
单元格位置是第二列,第一行,值为789.123*/
jxl.write.Numbernumber=newjxl.write.Number(1,0,789.123);
sheet.addCell(number);
//写入数据并关闭文件
book.write();
book.close();
}catch(Exceptione)
{
System.out.println(e);
}
}
}
importjava.io.BufferedWriter;
importjava.io.File;
importjava.io.FileWriter;
importjava.io.IOException;
importjxl.Cell;
importjxl.Sheet;
importjxl.Workbook;
importjxl.read.biff.BiffException;
//用java将excel数据导入txt
publicclassWriteTxt{
publicstaticvoidmain(String[]args){
//TODOAuto-generatedmethodstub
Stringfilepath="d:\\demo.xls";
try{
Workbookworkbook=Workbook.getWorkbook(newFile(filepath));
Sheetsheet=workbook.getSheet(0);
Filefile=newFile("d:/1.txt");
FileWriterfw=newFileWriter(file);
BufferedWriterbw=newBufferedWriter(fw);
//j为行数,getCell("列号","行号")
intj=sheet.getRows();
inty=sheet.getColumns();
for(inti=0;i
遇到的问题:
txt文件中单元格数据之间用|分割,用string.split("\\|");提取数据
用的jar包对excel2007不支持从而导致转换出的是空文件
excel文件转txt文件时,用tab键分隔分隔字符串数组时用String.split("\\",-1);
上线遇到的问题:
1.在windows上获取路径地址是以\分隔的,而在linux上获取的路径是以/分隔的,这要注意
2.默认情况下,Excel中每个单元格所能显示的数字为11位,输入超过11位的数值,系统自动将其转换为科学记数格式,当txt转excel时,有两种方法可以解决这个问题,第一种是在单元格数字前加个单引号,第二种是设置单元格的格式为文本格式,在上述代码中加入以下代码
WritableFontwf=newWritableFont(WritableFont.TIMES,12,WritableFont.NO_BOLD,false);
WritableCellFormatwcfF=newWritableCellFormat(NumberFormats.TEXT);
wcfF.setFont(wf);
CellViewcv=newCellView();
cv.setFormat(wcfF);
cv.setSize(10*265);
sheet.setColumnView(j,cv);
Labellabel=newLabel(j,n,s1[j]);
sheet.addCell(label);
3.当txt转excel在windows上转换成功时,到linux服务器上转出的excel中汉字变成了乱码,因为FileWriterfw=newFileWriter(file);这句代码采用默认字符集解析,经过尝试,使用GBK解析文件,用以下代码可不出现乱码,
BufferedReaderbw=newBufferedReader(newInputStreamReader(newFileInputStream(newFile(filen)),"GBK"));
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票