当前位置: 代码迷 >> J2SE >> jxl 操作Excel表解决方法
  详细解决方案

jxl 操作Excel表解决方法

热度:8708   发布时间:2013-02-25 00:00:00.0
jxl 操作Excel表
现有一个表 想把其他的数据添加到这个表中, 而不是重新建表,如何实现?高分求答

------解决方案--------------------------------------------------------
//通过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 code
 /**     * <一句话功能简述> 向EXl文件中写入一行     * <功能详细描述>     * @param wb  HSSFWorkbook     * @param strings  写入的字符串     * @param lineNum  写入的行号     * @param isTitle [参数说明] 是否是title     * @see [类、类#方法、类#成员]     */    public void writeLine(HSSFWorkbook wb, String[] strings, int lineNum,        boolean isTitle)    {        HSSFSheet sheet = null;        try        {            sheet = wb.getSheetAt(0);        }        catch (Exception e)        {            sheet = wb.createSheet("TaskzUpgradeReport");        }        HSSFRow hssfRow = sheet.createRow(lineNum);        HSSFCellStyle cellStyle1 = wb.createCellStyle();        if (isTitle)        {            //设置标题的背景色            cellStyle1.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);            cellStyle1.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);                        HSSFFont font2 = wb.createFont();                        //设置标题的字体            final short fontCode2 = 0x64;            font2.setBoldweight(fontCode2);            cellStyle1.setFont(font2);            cellStyle1.setBorderBottom(HSSFCellStyle.BORDER_THIN);            cellStyle1.setBorderLeft(HSSFCellStyle.BORDER_THIN);            cellStyle1.setBorderRight(HSSFCellStyle.BORDER_THIN);            cellStyle1.setBorderTop(HSSFCellStyle.BORDER_THIN);        }        //设置行高        final short height = 0x249;        hssfRow.setHeight(height);        int length = strings.length;        HSSFCell hssfCell = null;        for (int index = 0; index < length; index++)        {            // 创建列            hssfCell = hssfRow.createCell((short)index);            //此单元格设置列风格            hssfCell.setCellStyle(cellStyle1);                        //为单元格赋值            hssfCell.setCellValue(new HSSFRichTextString(strings[index]));            sheet.setColumnWidth((short)index, COLUMN_WEITH);        }    }
------解决方案--------------------------------------------------------
探讨

引用:
没办法读的时候修改源文件吧,至少我没找到方法。不知道jxl能操作公式不,poi可以操作公式的。

能否实现向已存在的表中添加数据?

------解决方案--------------------------------------------------------
http://blog.csdn.net/tkd03072010/article/details/6692366
看看这个
  相关解决方案