Poi对Excel的基本读写操作

写操作:

Java代码

  1. /**
  2. *
  3. * 层次结构就是workbook-->Sheet-->Row-->Cell
  4. * 只要按照这种层次结构操作就不会有什么大的问题
  5. * @author Administrator
  6. *
  7. */
  8. public class Test1 {
  9. public static void main(String args[]) throws IOException {
  10. //HSSFWorkbook对应的是2003
  11. //XSSFWorkbook对应的是2007
  12. //对于03和07它们的操作都是差不多的,只是在需要用07的时候把相应的HSSF前缀改成XSSF前缀就可以了
  13. //第一步建一个工作簿,即workbook
  14. Workbook workbook = new HSSFWorkbook();
  15. //第二步建一个工作表单,急sheet
  16. Sheet sheet = workbook.createSheet("mysheet1");
  17. for (int i=0;i<5;i++) {
  18. //有了表单以后就是行Row了,
  19. Row row = sheet.createRow(i);
  20. for (int j=0;j<5;j++) {
  21. //有了row以后就是row上的一个个小的单元格了
  22. Cell cell = row.createCell(j);
  23. //给单元格添加内容
  24. cell.setCellValue("row"+(i+1)+",column"+(j+1));
  25. }
  26. }
  27. //建一个用于存放新建的excel的文件输出流
  28. OutputStream os = new FileOutputStream("file/test1.xls");
  29. //把形成的workbook写到一个输出流里面
  30. workbook.write(os);
  31. os.close();
  32. }
  33. }

读操作:

Java代码

  1. public class Test4 {
  2. public static void main(String args[]) throws IOException {
  3. InputStream is = new FileInputStream("file/test1.xls");
  4. Workbook wb = new HSSFWorkbook(is);
  5. Sheet sheet = wb.getSheetAt(0);
  6. // 因为Row,Cell,Sheet都继承了java.lang.Iterator接口,所以可以用下面的方法来进行遍历
  7. for (Row row : sheet) {
  8. for (Cell cell : row) {
  9. int cellType = cell.getCellType();
  10. switch (cellType) {
  11. //在取数据的时候类型一定要取对,否则将抛出异常
  12. case Cell.CELL_TYPE_STRING:
  13. String str = cell.getRichStringCellValue().getString();
  14. System.out.println(str);// 对取得的数据的简单处理;
  15. break;
  16. case Cell.CELL_TYPE_BLANK:
  17. if (DateUtil.isCellDateFormatted(cell)) {
  18. System.out.println(cell.getDateCellValue());
  19. } else {
  20. System.out.println(cell.getNumericCellValue());
  21. }
  22. break;
  23. case Cell.CELL_TYPE_FORMULA:
  24. System.out.println(cell.getCellFormula());
  25. break;
  26. case Cell.CELL_TYPE_BOOLEAN:
  27. System.out.println(cell.getBooleanCellValue());
  28. break;
  29. default:
  30. System.out.println("---------------------");
  31. break;
  32. }
  33. }
  34. }
  35. //当然还可以这样来遍历
  36. //row是从1开始的,cell是从头0开始的,但是在创建的时候它们都是0-based;
  37. for (int i=0;i<sheet.getLastRowNum()+1;i++) {
  38. Row row = sheet.getRow(i);
  39. if (row==null)
  40. continue;
  41. for (int j=0;j<row.getLastCellNum();j++) {
  42. Cell cell = row.getCell(j);
  43. if (cell==null)
  44. continue;
  45. //在取数据的时候数据类型一定要取对,否则将抛出异常,like NumberFormatException
  46. System.out.println(cell.getStringCellValue());
  47. }
  48. }
  49. is.close();
  50. }
  51. }

合并单元格:

Java代码

  1. public static void main(String args[]) throws IOException {
  2. Workbook wb = new HSSFWorkbook();
  3. Sheet sheet = wb.createSheet("sheet1");
  4. Row row = sheet.createRow(1);
  5. Cell cell = row.createCell(1);
  6. cell.setCellValue("a test of merge!");
  7. //执行合并操作的语句
  8. sheet.addMergedRegion(new CellRangeAddress(
  9. 1,// 开始行
  10. 1,// 结束行
  11. 1,// 开始列
  12. 3// 结束列
  13. ));
  14. OutputStream os = new FileOutputStream("file/test3.xls");
  15. wb.write(os);
  16. os.close();
  17. }

换行:

Java代码

  1. public static void main(String args[]) throws IOException {
  2. Workbook wb = new HSSFWorkbook();
  3. Sheet sheet = wb.createSheet();
  4. Row row = sheet.createRow(6);
  5. sheet.autoSizeColumn(2);
  6. for (int i=0;i<5;i++) {
  7. Cell cell = row.createCell(i+2);
  8. CellStyle style = wb.createCellStyle();
  9. //to set cell newLine should set its wrap true
  10. style.setWrapText(true);
  11. //利用\n来实现换行操作,只有在Cell设置为setWrapText(true)的时候才能实现人为的换行
  12. cell.setCellValue("just use \n to wrap in a cell!");
  13. cell.setCellStyle(style);
  14. }
  15. OutputStream os = new FileOutputStream("file/test6_newLine.xls");
  16. wb.write(os);
  17. os.close();
  18. System.out.println("----------------------------");
  19. }

画图:

Java代码

  1. //drawing shapes
  2. /*
  3. * To create a shape you have to go through the following steps:
  4. 1.Create the patriarch.
  5. 2.Create an anchor to position the shape on the sheet.
  6. 3.Ask the patriarch to create the shape.
  7. 4.Set the shape type (line, oval, rectangle etc...)
  8. 5.Set any other style details converning the shape. (eg: line thickness, etc...)
  9. */
  10. HSSFPatriarch partriarch = (HSSFPatriarch) sheet5.createDrawingPatriarch();
  11. HSSFSimpleShape shape = partriarch.createSimpleShape(new HSSFClientAnchor(0,0,0,0,(short)3,3,(short)5,5));
  12. shape.setShapeType(HSSFSimpleShape.OBJECT_TYPE_OVAL);
  13. //shape可以设置很多的属性
  14. shape.setFillColor(255,200,200);
  15. shape.setLineStyle(HSSFSimpleShape.LINESTYLE_DASHGEL);
  16. //Text boxes are created using a different call:
时间: 2024-08-27 16:34:20

Poi对Excel的基本读写操作的相关文章

python实现对excel表的读写操作(一)

Part 1. 模块介绍: 使用python实现对excel表的读写操作有两个模块,分别为: 1. 对excel表读取模块 xlrd 0.9.3  :下载地址: https://pypi.python.org/pypi/xlrd 英文释意:The package is for reading data and formatting information from Excel files. 2. 对excel表写入模块 xlwt 0.7.5 : 下载地址:https://pypi.python.

通过python对excel文件的读写操作

通过xlwt对excel执行写操作 需要安装并导入xlwt模块 1 def set_style(name, height, bold=False): #一个name参数,一个高度参数,默认不加粗 2 style = xlwt.XFStyle() # 初始化样式 3 font = xlwt.Font() # 为样式创建字体 4 font.name = name # 'Times New Roman' 5 font.bold = bold #加粗 6 font.color_index = 4 #颜色

python对excel文件的读写操作

import xlrd,xlwt data = xlrd.open_workbook('a.xlsx') #读 table = data.sheets()[0] data_list = [] data_list.extend(table.row_values(0)) for item in data_list: print item ################# # 写 data = xlwt.Workbook() table = data.add_sheet('b') table.wri

使用POI来实现对Excel的读写操作

事实上我感觉直接贴代码就好了.代码里面差点儿做到每一行一个凝视.应该看起来会比較简单 代码托管在github上:https://github.com/chsj1/ExcelUtils package com.hjd.poiutils; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.Out

python excel读写操作

1.读操作 xlrd 下载地址:https://pypi.python.org/pypi/xlrd 使用代码 # encoding : utf-8 #设置编码方式 import xlrd #导入xlrd模块 #打开指定文件路径的excel文件 xlsfile = r'D:\AutoPlan\apisnew.xls' book = xlrd.open_workbook(xlsfile) #获得excel的book对象 #获取sheet对象,方法有2种: sheet_name=book.sheet_

Python 读写操作Excel —— 安装第三方库(xlrd、xlwt、xlutils)

数据处理是 Python 的一大应用场景,而 Excel 则是最流行的数据处理软件.因此用 Python 进行数据相关的工作时,难免要和 Excel 打交道. 如果仅仅是要以表单形式保存数据,可以借助 CSV 格式(一种以逗号分隔的表格数据格式)进行处理,Excel 也支持此格式.但标准的 Excel 文件(xls/xlsx)具有较复杂的格式,并不方便像普通文本文件一样直接进行读写,需要借助第三方库来实现. 常用的库是 python-excel 系列: xlrd.xlwt.xlutils xlr

POI对EXCEL的操作【重点:如何设置CELL格式为文本格式】

实际开发过程中通常用到的就是从数据库导出EXCEL表格了,JXL可以这样做,其实POI也可以(关于JXL与POI的异同可访问我之前总结的文章),之前写过POI对七种文档(当然也包括EXCEL)的内容读取操作的文章,这次要写的就非常重要了,就是开发中经常会用到的POI读取数据库导出EXCEL的操作,所谓导出EXCEL也就是生成带数据内容的新的EXCEL文件 目前的POI版本是3.7 下载地址:http://poi.apache.org/download.html#POI-3.7 必须包只有一个:p

Python—对Excel进行读写操作

学习Python的过程中,我们会遇到Excel的读写问题.通过搜索得知,我们可以使用xlwt module将数据写入Excel表格,使用xlrd module从Excel读取数据.下面介绍如何实现使用python对Excel进行读写操作. (1)对Excel的写操作: # -*- coding: utf-8 -*- #导入xlwt模块 import xlwt # 创建一个Workbook对象,这就相当于创建了一个Excel文件 book = xlwt.Workbook(encoding='utf

Apache POI读取和创建Excel ----01(简单操作)

public class ExcelCreatAndRead { /**     * 使用Apache POI创建Excel文档     * */    public static void createXL(){        /**Excel文件要存放的位置,假定在D盘下*/        String outputFile="D:\\test.xlsx";        try {        //创建新的Excel工作薄        XSSFWorkbook workboo