`
温柔一刀
  • 浏览: 860631 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

java操作Excel、PDF文件

    博客分类:
  • java
阅读更多
下面这些是在开发中用到的一些东西,有的代码贴的不是完整的,只是贴出了关于操作EXCEL的代码:


jxl是一个*国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可供使用,一个是POI,一个是jExcelAPI。其中功能相对POI比较弱一点。但jExcelAPI对中文支持非常好,API是纯Java的, 并不依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。 另外需要说明的是,这套API对图形和图表的支持很有限,而且仅仅识别PNG格式。

使用如下:

搭建环境

将下载后的文件解包,得到jxl.jar,放入classpath,安装就完成了。

基本操作

一、创建文件

拟生成一个名为“test.xls”的Excel文件,其中第一个工作表被命名为
“第一页”,大致效果如下:
 package  test;

 // 生成Excel的类 
 import  java.io.File;

 import  jxl.Workbook;
 import  jxl.write.Label;
 import  jxl.write.WritableSheet;
 import  jxl.write.WritableWorkbook;

 public   class  CreateExcel   {
     public   static   void  main(String args[])   {
         try    {
             //  打开文件 
             WritableWorkbook book  =  Workbook.createWorkbook( new  File( " test.xls " ));
             //  生成名为“第一页”的工作表,参数0表示这是第一页 
             WritableSheet sheet  =  book.createSheet( " 第一页 " ,  0 );
             //  在Label对象的构造子中指名单元格位置是第一列第一行(0,0)
             //  以及单元格内容为test 
             Label label  =   new  Label( 0 ,  0 ,  " test " );

             //  将定义好的单元格添加到工作表中 
             sheet.addCell(label);

             /**/ /* 
             * 生成一个保存数字的单元格 必须使用Number的完整包路径,否则有语法歧义 单元格位置是第二列,第一行,值为789.123
              */ 
            jxl.write.Number number  =   new  jxl.write.Number( 1 ,  0 ,  555.12541 );
            sheet.addCell(number);

             //  写入数据并关闭文件 
             book.write();
            book.close();

        }   catch  (Exception e)   {
            System.out.println(e);
        } 
    } 
} 
 


   编译执行后,会产生一个Excel文件。

三、读取文件

以刚才我们创建的Excel文件为例,做一个简单的读取操作,程序代码如下:
 package  test;

 // 读取Excel的类 
 import  java.io.File;

 import  jxl.Cell;
 import  jxl.Sheet;
 import  jxl.Workbook;

 public   class  ReadExcel   {
     public   static   void  main(String args[])   {
         try    {
            Workbook book  =  Workbook.getWorkbook( new  File( " test.xls " ));
             //  获得第一个工作表对象 
             Sheet sheet  =  book.getSheet( 0 );
             //  得到第一列第一行的单元格 
             Cell cell1  =  sheet.getCell( 0 ,  0 );
            String result  =  cell1.getContents();
            System.out.println(result);
            book.close();
        }   catch  (Exception e)   {
            System.out.println(e);
        } 
    } 
} 
 


  程序执行结果:test

四、修改文件
利用jExcelAPI可以修改已有的Excel文件,修改Excel文件的时候,除了打开文件的方式不同之外,
其他操作和创建Excel是一样的。下面的例子是在我们已经生成的Excel文件中添加一个工作表:
 package  test;

 import  java.io.File;

 import  jxl.Workbook;
 import  jxl.write.Label;
 import  jxl.write.WritableSheet;
 import  jxl.write.WritableWorkbook;

 public   class  UpdateExcel   {
     public   static   void  main(String args[])   {
         try    {
             //  Excel获得文件 
             Workbook wb  =  Workbook.getWorkbook( new  File( " test.xls " ));
             //  打开一个文件的副本,并且指定数据写回到原文件 
             WritableWorkbook book  =  Workbook.createWorkbook( new  File( " test.xls " ),
                    wb);
             //  添加一个工作表 
             WritableSheet sheet  =  book.createSheet( " 第二页 " ,  1 );
            sheet.addCell( new  Label( 0 ,  0 ,  " 第二页的测试数据 " ));
            book.write();
            book.close();
        }   catch  (Exception e)   {
            System.out.println(e);
        } 
    } 
} 
 


其他操作

一、 数据格式化

在Excel中不涉及复杂的数据类型,能够比较好的处理字串、数字和日期已经能够满足一般的应用。

1、 字串格式化

字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont和
WritableCellFormat类来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,
为方便叙述,我们为每一行命令加了编号:
 WritableFont font1 = 
  new  WritableFont(WritableFont.TIMES, 16 ,WritableFont.BOLD); ①

 WritableCellFormat format1 = new  WritableCellFormat(font1); ②

 Label label = new  Label( 0 , 0 ,”data  4  test”,format1) ③

 
  其中①指定了字串格式:字体为TIMES,字号16,加粗显示。WritableFont有非常丰富的
 构造子,供不同情况下使用,jExcelAPI的java-doc中有详细列表,这里不再列出。

 ②处代码使用了WritableCellFormat类,这个类非常重要,通过它可以指定单元格的各种
 属性,后面的单元格格式化中会有更多描述。

 ③处使用了Label类的构造子,指定了字串被赋予那种格式。

 在WritableCellFormat类中,还有一个很重要的方法是指定数据的对齐方式,比如针对我们
 上面的实例,可以指定:

   // 把水平对齐方式指定为居中 
  format1.setAlignment(jxl.format.Alignment.CENTRE);

  // 把垂直对齐方式指定为居中 
  format1.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);
 

二、单元格操作

Excel中很重要的一部分是对单元格的操作,比如行高、列宽、单元格合并等,所幸jExcelAPI
提供了这些支持。这些操作相对比较简单,下面只介绍一下相关的API。

1、 合并单元格
  WritableSheet.mergeCells( int  m, int  n, int  p, int  q); 

  // 作用是从(m,n)到(p,q)的单元格全部合并,比如: 
  WritableSheet sheet = book.createSheet(“第一页”, 0 );

  // 合并第一列第一行到第六列第一行的所有单元格 
  sheet.mergeCells( 0 , 0 , 5 , 0 );
 

合并既可以是横向的,也可以是纵向的。合并后的单元格不能再次进行合并,否则会触发异常。

2、 行高和列宽
  WritableSheet.setRowView( int  i, int  height);

  // 作用是指定第i+1行的高度,比如:

  // 将第一行的高度设为200 
  sheet.setRowView( 0 , 200 );

 WritableSheet.setColumnView( int  i, int  width);

  // 作用是指定第i+1列的宽度,比如:

  // 将第一列的宽度设为30 
  sheet.setColumnView( 0 , 30 );
  
  


jExcelAPI还有其他的一些功能,比如插入图片等,这里就不再一一介绍,读者可以自己探索。

其中:如果读一个excel,需要知道它有多少行和多少列,如下操作:
 Workbook book  =  Workbook.getWorkbook( new  File( " 测试1.xls " ));
         //  获得第一个工作表对象 
         Sheet sheet  =  book.getSheet( 0 );
         //  得到第一列第一行的单元格 
          int  columnum  =  sheet.getColumns(); //  得到列数 
          int  rownum  =  sheet.getRows(); //  得到行数 
         System.out.println(columnum);
        System.out.println(rownum);
         for  ( int  i  =   0 ; i  <  rownum; i ++ ) //  循环进行读写 
            {
             for  ( int  j  =   0 ; j  <  columnum; j ++ )   {
                Cell cell1  =  sheet.getCell(j, i);
                String result  =  cell1.getContents();
                System.out.print(result);
                System.out.print( " \t " );
            } 
            System.out.println();
        } 
        book.close(); 
       
分享到:
评论
2 楼 温柔一刀 2006-10-09  
将Excel文件内容写入到数据库
  public   class  EStudentInsertExcelController  extends  SimpleFormController   {

     private  IStudent_infoManage studentManage;

    @Override
     protected  ModelAndView onSubmit(HttpServletRequest request,
            HttpServletResponse response, Object command, BindException errors)
             throws  Exception   {
        Student_info student_info  =  (Student_info) command;
         try    {            
            MultipartHttpServletRequest multipartRequest  =  (MultipartHttpServletRequest) request;
            MultipartFile file  =  multipartRequest.getFile( " Excelfile " );  //  获得文件: 
             File toFile  =   new  File( " c:\\学生信息临时文件.xls " ); //  产生文件名和空文件 
             file.transferTo(toFile); //  文件上传 
             Workbook book  =  Workbook.getWorkbook(toFile); // 得到工作薄             
             Sheet sheet  =  book.getSheet( 0 ); //  获得第一个工作表对象 
              int  row  =  sheet.getRows(); //  /得到该sheet的行数 
              int  column  =  sheet.getColumns();  //  得到该sheet的列数     
             System.out.println( " 数据行数= " + row);
            System.out.println( " 数据列数= " + column);
             for ( int  i = 1 ;i < row;i ++ )
              {
                 for ( int  j = 0 ;j < column;j ++ )
                  {
                    System.out.println( " j= " + j);
                    sheet.getCell(j, i).getContents(); //  得到第j列第i行的单元格的类容         
                     student_info.setStudentID(sheet.getCell(j, i).getContents());    
                   ........................  
                }     
                 if  ( this .studentManage.getStudentByStudentID(
                        student_info.getStudentID()).size()  !=   0 )
                     return   new  ModelAndView( " education/e-studentInfoAddError " );
                 this .studentManage.insertStudent_info(student_info);    
            }                 
            book.close();
             return   new  ModelAndView( " education/e-studentInfoAddExcelSuccess " , " row " , new  Integer(row - 1 ));
        }   catch  (Exception e)   {                    
            e.printStackTrace();
        } 
         return   new  ModelAndView( " education/e-studentInfoAddExcelError " );
    } 
 
      public   void  setStudentManage(IStudent_infoManage studentManage)   {
         this .studentManage  =  studentManage;
    }     
} 
1 楼 温柔一刀 2006-10-09  
ExcelBean.java文件用于生成Excel

public class ExcelBean {

    public String expordExcel(OutputStream os, List courseList,List studentList)
            throws Exception {

        WritableWorkbook wbook = Workbook.createWorkbook(os); // 建立excel文件
        String tmptitle = "课程“"+((Course_info)courseList.get(0)).getCource_name()+"”的选课学生列表"; // 标题
        WritableSheet wsheet = wbook.createSheet("第一页", 0); // sheet名称
        // 设置excel标题
        WritableFont wfont = new WritableFont(WritableFont.ARIAL, 16,
                WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE,
                Colour.BLACK);
        WritableCellFormat wcfFC = new WritableCellFormat(wfont);
        wsheet.addCell(new Label(1, 0, tmptitle, wcfFC));
        wfont = new jxl.write.WritableFont(WritableFont.ARIAL, 14,
                WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE,
                Colour.BLACK);
        wcfFC = new WritableCellFormat(wfont);
        // 开始生成主体内容                
        wsheet.addCell(new Label(0, 2, "课程名称"));
        wsheet.addCell(new Label(1, 2, "学 号"));
       .........
        for(int i=3;i<studentList.size()+3;i++)
        {
            wsheet.addCell(new Label(0, i, ((Course_info)courseList.get(0)).getCource_name()));
            wsheet.addCell(new Label(1, i, ((Student_info)studentList.get(0)).getStudentID()));
      ...........
        }        
        // 主体内容生成结束        
        wbook.write(); // 写入文件
        wbook.close();
        os.close();
        return "success";
    }
}


控制器:

public class EExcelDownController extends AbstractController {
    
    private ICourse_infoManage courseManage;

    public void setCourseManage(ICourse_infoManage courseManage) {
        this.courseManage = courseManage;
    }

    @Override
    protected ModelAndView handleRequestInternal(HttpServletRequest request,
            HttpServletResponse response) throws Exception {    
        Integer course_id=new Integer(request.getParameter("course_id"));
        List courseList=this.courseManage.getCourseById(course_id);        
        List studentList = this.courseManage.getStudentByCourseId(course_id);
         try {    
            OutputStream os = response.getOutputStream();// 取得输出流
            response.reset();// 清空输出流
            response.setHeader("Content-disposition", "attachment; filename=student.xls");// 设定输出文件头
            response.setContentType("application/msexcel");// 定义输出类型
            ExcelBean excelBean = new ExcelBean();
            excelBean.expordExcel(os,courseList,studentList);// 调用生成excel文件bean
        } catch (Exception e) {
            System.out.println(e);
        }            
        return null;    
    }
}

相关推荐

    java Excel文件转PDF文件

    在Java编程环境中,将Excel文件转换为PDF文件是一项常见的任务,尤其在数据报告或文档格式转换的场景下。本文将详细介绍如何使用Apache POI库处理Excel数据,以及使用iText库将这些数据导出为PDF格式。Apache POI是...

    利用JAVA操作EXCEL文件.pdf

    ### 利用JAVA操作EXCEL文件的关键知识点 #### 一、JAVA EXCEL API 简介 - **项目背景**:随着Web应用的发展,越来越多的应用场景需要通过Web端操作Excel文件,而传统的CSV文件虽然可以被Excel打开,但无法实现对...

    java实现excel转换 pdf文件

    在Java编程环境中,将Excel文件转换为PDF格式是一项常见的任务,尤其在数据报告或文档交换中。Aspose.Cells是一款强大的库,它提供了丰富的API来处理各种办公文档,包括Excel到PDF的转换。在这个过程中,无需依赖...

    Java Excel转为PDF(aspose)工具类 复造轮子

    在这个工具类中,`convertExcelToPdf`方法接收Excel文件路径和输出PDF文件路径作为参数,加载Excel文件到Workbook对象,然后创建PdfSaveOptions实例,设置保存格式为PDF。为了保持图片质量,可以调整图片的压缩质量...

    JAVA读取WORD_EXCEL_POWERPOINT_PDF文件的方法(poi)

    JAVA 读取 WORD_EXCEL_POWERPOINT_PDF 文件的方法(poi) JAVA 读取 WORD_EXCEL_POWERPOINT_PDF 文件的方法是使用 Apache POI 库来实现的。POI 库是一个开放源代码的 Java 库,提供了对 Microsoft Office 文件格式...

    java excel转pdf

    3. 执行转换:调用Workbook的save方法,传入目标PDF文件路径和之前创建的SaveOptions对象。 4. 关闭资源:转换完成后,记得关闭Workbook以释放系统资源。 在提供的压缩包“AsposeCells 8.5.2”中,应该包含Aspose....

    Java aspose Excel转为 pdf工具类

    在这个示例中,`convertExcelToPdf`方法接收Excel文件路径和PDF文件路径作为参数,然后使用Aspose.Cells的Workbook类打开Excel文件,并通过PdfSaveOptions设置保存为PDF格式。最后,调用`save`方法将转换后的结果...

    java导出文件到 pdf,excel,word

    在Java中,我们可以使用Apache PDFBox库来创建和编辑PDF文件。PDFBox提供了API来添加文本、图像、表格等元素,并可以设置字体、颜色、页面大小等属性。例如,你可以创建一个PDFDocument对象,然后通过...

    java实现excel导入导出.pdf

    JXL(Java Excel API)是一个开源的 Java 库,用于读写 Excel 文件。使用 JXL 库可以实现 Excel 文件的读取、写入和编辑。 在上面的代码中,使用 JXL 库实现了 Excel 文件的写入。首先,需要导入 JXL 库的相关类,...

    Jacob Word excel 转PDF 合并PDF文件

    标题提到的"Jacob Word excel 转PDF 合并PDF文件"是指使用Jacob库来将Microsoft Word和Excel文档转换为PDF格式,并进一步合并多个PDF文件。Jacob(Java Advanced COM Bridge)是一个Java库,它允许Java应用程序与...

    java操作excel代码[文].pdf

    本文档主要介绍了使用 Java 语言操作 Excel 文件的代码实现,涵盖了创建新的 Excel 文件、添加表头、合并单元格、设置单元格样式等功能。 创建新的 Excel 文件 在 Java 中想要操作 Excel 文件,需要使用 Apache ...

    Java操作Word, Excel, PDF文档

    ### Java操作Word、Excel、PDF文档 在日常工作中,Word、Excel 和 PDF 是最常用的办公文档格式之一。通过 Java 编程语言可以实现对这些文档的操作自动化,这对于提高工作效率具有重要意义。本文将详细介绍如何使用 ...

    java web在线预览pdf、word、excel

    对于PDF文件,在Java Web环境中,可以使用Apache PDFBox、iText等库来读取和处理PDF内容。这些库能够读取PDF文件并将其转换为流式数据,从而可以通过HTTP响应返回给前端。而对于Word和Excel,我们可以使用Apache POI...

    java生成excel图表

    3. iText:一个Java库,用于生成PDF文件。 Java生成Excel图表的常用方法: 1. 使用ChartFactory创建JFreeChart对象。 2. 使用DefaultPieDataset创建饼状图数据集。 3. 使用CategoryDataset创建柱状图数据集。 ...

    java导出excel pdf 报表

    本文将深入探讨如何使用Java实现这一功能,包括处理Excel和PDF的库、基本操作以及优化技巧。 首先,Java中常用的库有Apache POI用于处理Excel,iText或Apache FOP用于处理PDF。Apache POI是Java API,专门用于读写...

    Word,Excel,PPT等转PDF文件JAVA源代码

    3. **创建PDF**:利用iText或PDFBox库创建一个新的PDF文件,然后按照PDF的规范,将之前处理好的内容写入PDF中。对于图像,可能需要先将其转换为PDF支持的格式。 4. **样式转换**:确保转换后的PDF文件能保持源文件...

    java导出Excel文件.pdf

    文档标题为“java导出Excel文件.pdf”,描述了从导入依赖、配置文件、前端实现到后端处理的完整流程。涉及到的技术标签包括POI、Vue、Spring Boot以及jqGrid。我们接下来将按照标题和描述的要求,详细解读各个部分的...

    Java中Excel转图片工具包(纯java)

    通过Apache POI,我们可以读取Excel工作表,然后使用库中的方法将这些工作表写入PDF文件。 2. **PDF转图片**:完成Excel到PDF的转换后,接下来是将PDF转换为图片。一个常用的库是PDFBox,这也是Apache的一个项目,...

    Java处理Excel文件-excel文件的创建,删除,写入,读取.pdf

    本示例介绍了一个使用Apache POI库来操作Excel(.xls格式)文件的Java类——`ExcelManage`。Apache POI是一个流行的开源库,专门用于读写Microsoft Office格式的文件,包括Excel。 `ExcelManage`类包含以下几个核心...

Global site tag (gtag.js) - Google Analytics