POI操作Excel表格
来源:互联网 发布:增值税发票抵扣软件 编辑:程序博客网 时间:2024/06/05 17:37
一、所需的jar包(http://download.csdn.net/detail/huangzebiao007/6375115)
二、主要的操作方法
1、读取excel文件
InputStream in = new FileInputStream(file);
HSSFWorkbook wb = new HSSFWorkbook(in);
2、写入excel表格
HSSFWorkbook wb = new HSSFWorkbook();
或:
HSSFWorkbook wb = new HSSFWorkbook(in);
//这里对workbook进行一些操作
OutputStream out = new FileOutputStream(file);
wb .write(out);
3、sheet操作
HSSFSheet sheet = wb.getSheetAt(0);//得到sheet,从0开始
HSSFSheet sheet = wb.getSheet(sheetName))//sheet的名字
HSSFSheet sheet = wb.createSheet(sheetName); //创建sheet
HSSFSheet sheet = wb.cloneSheet(0); //复制sheet
HSSFSheet sheet = wb.setSheetName(i, "SheetName new"); //修改sheet名
HSSFSheet sheet = wb.removeSheetAt(0); //删除sheet
wb.getNumberOfSheets() = 3 //Excel有3个sheet,得到的就是sheet的个数 //查看有多少个sheet
4、row操作
HSSFRow row = sheet.getRow(0);//得到row,从0开始
HSSFRow row = sheet.createRow(0);//创建row
sheet.removeRow(row);//删除row
//移动行:只移动内容,不牵扯行的删除和插入
//移动行(把第1行和第2行移到第5行之后)
sheet.shiftRows(0, 1, 5);
//移动行(把第3行和第4行往上移动1行)
sheet.shiftRows(2, 3, -1);
sheet.setDefaultRowHeight((short)100);//设置默认行高
sheet.getRow(2).setHeight((short)(100 * 20));//设置行高
sheet.getLastRowNum() = 3 //Excel中Sheet1表有4行数据,所以得到的数据是3
5、列操作
wb.getSheet("sheetname7").setDefaultColumnWidth(12);//设置默认列宽
sheet.setColumnWidth(0, 5 * 256);//第一列,//设置列宽
row.getLastCellNum() = 4//Excel中Sheet1表有4列数据,所以得到的数据是4
//CellRangeAddress(int firstRow, int lastRow, int firstCol, int lastCol)
wb.getSheet("sheetname10").addMergedRegion(new CellRangeAddress(0, 1, 0, 2));//合并第一行和第二行的第一列到第三列范围的单元格
HSSFCell cell = row.createCell(0);//创建单元格
HSSFCell cell = row.getCell(0);//得到单元格
row.removeCell(cell);//删除单元格
6、单元格样式操作
public static HSSFCellStyle createCellStyle( HSSFWorkbook workbook) {HSSFCellStyle style = workbook.createCellStyle();// 设置上下左右四个边框style.setBorderTop(HSSFBorderFormatting.BORDER_THIN);style.setBorderBottom(HSSFBorderFormatting.BORDER_THIN);style.setBorderLeft(HSSFBorderFormatting.BORDER_THIN);style.setBorderRight(HSSFBorderFormatting.BORDER_THIN);// 设置上下左右四个边框颜色style.setTopBorderColor(HSSFColor.BLACK.index);style.setBottomBorderColor(HSSFColor.BLACK.index);style.setLeftBorderColor(HSSFColor.BLACK.index);style.setRightBorderColor(HSSFColor.BLACK.index);// 设置单元格背景色,颜色参考文档 style.setFillForegroundColor(HSSFColor.LIGHT_GREEN.index);style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);// 设置字体格式,并将字体格式设置到HSSFCellStyle上HSSFFont font = workbook.createFont();font.setFontName("宋体");font.setFontHeightInPoints((short) 11); font.setItalic(true); //斜体 font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); //粗体 font.setColor(HSSFColor.YELLOW.index); //文字颜色style.setFont(font);// 设置单元格居中,水平,竖直style.setAlignment(HSSFCellStyle.ALIGN_CENTER); style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);return style;}
7、单元格值操作
cell.setCellStyle(style);cell.setCellValue("aaa");public static void getCellValue(HSSFCell cell) {if(cell == null){return; }else if(cell.getCellType() == HSSFCell.CELL_TYPE_BLANK){ System.out.println("CELL_TYPE_BLANK"); }else if(cell.getCellType() == HSSFCell.CELL_TYPE_STRING){ System.out.println(cell.getRichStringCellValue().getString()); }else if(cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){ System.out.println(cell.getNumericCellValue()); }else if(cell.getCellType() == HSSFCell.CELL_TYPE_BOOLEAN){ System.out.println(cell.getBooleanCellValue()); }else if(cell.getCellType() == HSSFCell.CELL_TYPE_FORMULA){System.out.println(cell.getNumericCellValue()+" 公式为:"+cell.getCellFormula()); } }
- POI操作Excel表格
- POI操作Excel表格
- poi操作Excel表格
- POI操作excel表格
- POI操作 导出Excel表格
- POI 操作Excel表格系列2 --- 读取Excel表格
- POI 对excel表格基本操作Demo
- poi导出excel表格
- POI读取excel表格
- POI导出Excel表格
- POI解析excel表格
- poi读取excel表格
- poi读写excel表格
- POI操作Excel表格系列5 --- 遇到的问题
- 操作 POI 从数据库导出数据到excel表格
- Java实现操作excel表格(基于poi.jar)
- Apache POI封装工具类: 操作Excel表格
- 其他-poi的使用(操作excel表格)
- OpenGL在64位VS2012下的配置
- huge integer 加减运算 参考代码
- 值容器
- 解决问题(二)——Log4j
- 向数据库插入数据后返回新插入行的主键
- POI操作Excel表格
- hdu 4455 Substrings(找规律&DP)
- 盗梦空间
- 表空间脱机
- oraInst.loc 和 oratab文件
- 关于LNK2019错误的解决方法
- CUDA学习笔记
- DIV+CSS规范命名大全集合
- C++知识