读写exceljava

java读写excel问题

我是这么想的…

写入excel文档的函数开头改成这样试试

File file = new File(dir);//这是你的excel文件

Workbook rw = Workbook.getWorkbook(file);//这个你前面的代码好像有了,就不要了吧

WritableWorkbook wwb = Workbook.createWorkbook(file, rw);

WritableSheet ws = wwb.getSheet(0);//用get方法而不是creat,这个应该是原因所在啦

我估计是由于excel文件已经存在了,再creat一个sheet会覆盖原来的文件,你写入的时候是不是以前写入的数据都没有了???我以前用过jxl,不过用得不好,大家一起进步吧,上面的代码不一定有用,你看看是不是我说的那个覆盖源文件的原因…

java如何读写excel2010

package com.b2bjy.crm.util;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.InputStream;

import java.text.DecimalFormat;

import java.util.ArrayList;

import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFDateUtil;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.DateUtil;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class POIExcelUtil

{

/** *//** 总行数 */

private int totalRows = 0;

/** *//** 总列数 */

private int totalCells = 0;

/** *//** 构造方法 */

public POIExcelUtil()

{}

/** *//**

* ul

* liDescription:[根据文件名读取excel文件]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @param fileName

* @return

* @throws Exception

*/

public ArrayListString read(String fileName)

{

ArrayListString dataLst = new ArrayListString();

/** *//** 检查文件名是否为空或者是否是Excel格式的文件 */

if (fileName == null || !fileName.matches(“^.+\\.(?i)((xls)|(xlsx))$”))

{

return dataLst;

}

boolean isExcel2003 = true;

/** *//** 对文件的合法性进行验证 */

if (fileName.matches(“^.+\\.(?i)(xlsx)$”))

{

isExcel2003 = false;

}

/** *//** 检查文件是否存在 */

File file = new File(fileName);

if (file == null || !file.exists())

{

return dataLst;

}

try

{

/** *//** 调用本类提供的根据流读取的方法 */

dataLst = read(new FileInputStream(file), isExcel2003);

}

catch (Exception ex)

{

ex.printStackTrace();

}

/** *//** 返回最后读取的结果 */

return dataLst;

}

/** *//**

* ul

* liDescription:[根据流读取Excel文件]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @param inputStream

* @param isExcel2003

* @return

*/

public ArrayListString read(InputStream inputStream,

boolean isExcel2003)

{

ArrayListString dataLst = null;

try

{

/** *//** 根据版本选择创建Workbook的方式 */

Workbook wb = isExcel2003 ? new HSSFWorkbook(inputStream)

: new XSSFWorkbook(inputStream);

dataLst = read(wb);

}

catch (IOException e)

{

e.printStackTrace();

}

return dataLst;

}

/** *//**

* ul

* liDescription:[得到总行数]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @return

*/

public int getTotalRows()

{

return totalRows;

}

/** *//**

* ul

* liDescription:[得到总列数]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @return

*/

public int getTotalCells()

{

return totalCells;

}

/** *//**

* ul

* liDescription:[读取数据]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @param wb

* @return

*/

private ArrayListString read(Workbook wb)

{

ArrayListString rowLst = new ArrayListString();

/** *//** 得到第一个shell */

Sheet sheet = wb.getSheetAt(0);

this.totalRows = sheet.getPhysicalNumberOfRows();

if (this.totalRows = 1 sheet.getRow(0) != null)

{

this.totalCells = sheet.getRow(0).getPhysicalNumberOfCells();

}

/** *//** 循环Excel的行 */

for (int r = 0; r this.totalRows; r++)

{

Row row = sheet.getRow(r);

if (row == null)

{

continue;

}

/** *//** 循环Excel的列 */

for (short c = 0; c 1; c++)

{

Cell cell = row.getCell(c);

String cellValue = “”;

if (cell == null)

{

rowLst.add(cellValue);

continue;

}

/** *//** 处理数字型的,自动去零 */

if (Cell.CELL_TYPE_NUMERIC == cell.getCellType())

{

cellValue = getRightStr(cell.getNumericCellValue() + “”);

}

/** *//** 处理字符串型 */

else if (Cell.CELL_TYPE_STRING == cell.getCellType())

{

cellValue = cell.getStringCellValue();

}

/** *//** 处理布尔型 */

else if (Cell.CELL_TYPE_BOOLEAN == cell.getCellType())

{

cellValue = cell.getBooleanCellValue() + “”;

}

/** *//** 其它的,非以上几种数据类型 */

else

{

cellValue = cell.toString() + “”;

}

rowLst.add(cellValue);

}

}

return rowLst;

}

/** *//**

* ul

* liDescription:[正确地处理整数后自动加零的情况]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @param sNum

* @return

*/

private String getRightStr(String sNum)

{

DecimalFormat decimalFormat = new DecimalFormat(“#.000000”);

String resultStr = decimalFormat.format(new Double(sNum));

if (resultStr.matches(“^[-+]?\\d+\\.[0]+$”))

{

resultStr = resultStr.substring(0, resultStr.indexOf(“.”));

}

return resultStr;

}

/** *//**

* ul

* liDescription:[测试main方法]/li

* liCreated by [Huyvanpull] [Jan 20, 2010]/li

* liMidified by [modifier] [modified time]/li

* ul

*

* @param args

* @throws Exception

*/

public String getPhones(){

ArrayListString dataLst = new POIExcelUtil().read(“D:\\b.xls”);

StringBuffer rowData = new StringBuffer();

for (int i = 0; i dataLst.size()-1; i++) {

rowData.append(dataLst.get(i)).append(“,”);

}

rowData.append(dataLst.get(dataLst.size()-1));

if (rowData.length() 0)

{

System.out.println(rowData);

}

return rowData.toString();

}

public static void main(String[] args) throws Exception

{

System.out.println(new POIExcelUtil().getPhones());

}

}

读写exceljava

java能读写同一个excel吗

JXL(Java Excel API)是一个用来动态读写Excel文件的开源框架,利用它可以在任何支持Java的操作系统上动态读写Excel文件。JXL的主页是:,可以在这里下载到它的最新的版本。

你可以分别通过如下命令

java -jar jxl.jar -xml test.xls

java -jar jxl.jar -cvs test.xls

以xml和cvs格式查看test.xls,这是因为JXL作者实现了一个用来演示的jxl.demo.Demo的类。

当然我们使用JXL主要是用它来动态读写Excel文件。现在就来看看JXL在对Excel的读和写上都提供了那些支持。

先来看看Excel文件中都有写上面对象

1 文件对象 2工作簿对象 3 单元格对象。

相应的在JXL中就有Workbook,Sheet ,Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。

我们先想想一下读取步骤,不管是什么样的Excel操作框架必定都要经历

1选取Excel文件,2选择工作簿,3选择Cell,4读取信息。

那么现在就可以看看JXL中这四步骤如何体现:

//通过Workbook的静态方法getWorkbook选取Excel文件

Workbook workbook = Workbook.getWorkbook(new File(“myfile.xls”));

//通过Workbook的getSheet方法选择第一个工作簿(从0开始)

Sheet sheet = workbook.getSheet(0);

//通过Sheet方法的getCell方法选择位置为C2的单元格(两个参数都从0开始)

Cell c2 = sheet.getCell(2,1);

//通过Cell的getContents方法把单元格中的信息以字符的形式读取出来

String stringc2 = c2.getContents();

可以看到正是刚才所说的四个步骤。

我们都知道Excel单元格是有格式的,那么这些信息如何取得。

Cell提供了一个getType方法能够返回单元格的类型信息,同时JXL提供了一个CellType类用来预设Excel中的类型信息,而且JXL提供了一些Cell类的子类用来分别用来表示各种类型的单元格,如LabelCell,NumberCell,DateCell分别表示字符、数值、日期类型的单元格。所以我们可以这样写:

if (c2.getType() == CellType.NUMBER)

{

? NumberCell nc = (NumberCell) c2;

? numberb2 = nc.getValue();

}

最后不要忘记关闭workbook以释放资源:

workbook.close();

现在总结一下:三个对象,四个步骤,注意格式。就可以轻松的从Excel文件中读取数据。

怎么用java将一个excel里面数据读出并写入另一个excel?

需要对Excel中的数据进行读取操作。

一、在开始进行Java读写Excel前,需要先下一个jxl的jar包,这个jar包中提供了相关读写Excel的方法,将jxl.jar放到classpath下或者在工程的buildpath中添加jxl.jar后,便可以开始Java读写Excel了。

二、Java读取Excel数据,首先,创建一个xls文件(如:jxltest.xls),然后在文件中添加一些数据,Excel文件创建完成后,便可以开始写代码读取了。

三、进行一个小小的扩展,读取一个目录下的所有Excel文件,读取的每个Excel文件的数据写入到不同的txt中。

四、生成EXCEL需要手动写查询语句把ORACLE数据库中的数据查询出来,再通过操作写到EXCEL文件里面。通过EXCEL把数据读取到ORACLE,同样需要去读取EXCEL工作薄里面的内容,再通过INSERT语句去插入数据库操作。

浅谈JAVA读写Excel的几种途径

需要对Excel中的数据进行读取操作。一、在开始进行Java读写Excel前,需要先下一个jxl的jar包,这个jar包中提供了相关读写Excel的方法,将jxl.jar放到classpath下或者在工程的buildpath中添加jxl.jar后,便可以开始Java读写Excel了。二、Java读取Excel数据,首先,创建一个xls文件(如:jxltest.xls),然后在文件中添加一些数据,Excel文件创建完成后,便可以开始写代码读取了。三、进行一个小小的扩展,读取一个目录下的所有Excel文件,读取的每个Excel文件的数据写入到不同的txt中。四、生成EXCEL需要手动写查询语句把ORACLE数据库中的数据查询出来,再通过操作写到EXCEL文件里面。通过EXCEL把数据读取到ORACLE,同样需要去读取EXCEL工作薄里面的内容,再通过INSERT语句去插入数据库操作。

java中怎样从Excel中读写数据

Java EXCEL API简介 

Java Excel是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容、创建新的Excel文件、更新已经存在的Excel文件。使用该API非Windows操作系统也可以通过纯Java应用来处理Excel数据表。因为是使用Java编写的,所以我们在Web应用中可以通过JSP、Servlet来调用API实现对Excel数据表的访问。

应用示例 

从Excel文件读取数据表 

Java Excel API既可以从本地文件系统的一个文件(.xls),也可以从输入流中读取Excel数据表。读取Excel数据表的第一步是创建Workbook(术语:工作薄),下面的代码片段举例说明了应该如何操作:  需要用到一个开源的jar包,jxl.jar。

File file = new File(“c:\\a.xls”);  

InputStream in = new FileInputStream(file);  

Workbook workbook = Workbook.getWorkbook(in);  

//获取第一张Sheet表  

Sheet sheet = workbook.getSheet(0);  

  

//我们既可能通过Sheet的名称来访问它,也可以通过下标来访问它。如果通过下标来访问的话,要注意的一点是下标从0开始,就像数组一样。  

//获取第一行,第一列的值   

Cell c00 = rs.getCell(0, 0);   

String strc00 = c00.getContents();   

//获取第一行,第二列的值   

Cell c10 = rs.getCell(1, 0);   

String strc10 = c10.getContents();   

//我们可以通过指定行和列得到指定的单元格Cell对象  

  Cell cell = sheet.getCell(column, row);  

  //也可以得到某一行或者某一列的所有单元格Cell对象  

  Cell[] cells = sheet.getColumn(column);  

  Cell[] cells2 = sheet.getRow(row);  

  //然后再取每一个Cell中的值  

  String content = cell.getContents();

本文来自投稿,不代表【】观点,发布者:【

本文地址: ,如若转载,请注明出处!

举报投诉邮箱:253000106@qq.com

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2024年3月24日 04:15:02
下一篇 2024年3月24日 04:20:12

发表回复

登录后才能评论



关注微信