`

jexcelapi使用小记

 
阅读更多
jexcelapi是一个开源项目,主要用来操作excel.
主页地址:
http://www.andykhan.com/jexcelapi/

现在做一个项目用到了它,根据不同的公司生成不同的文件夹,
在相应的文件夹下生成对应的xls. 这里只帖出生成xls部分核心代码:
    public void generateXls()
    
{
        
try
        
{
            
/** *//** **********创建工作簿************ */
            WritableWorkbook workbook 
= Workbook.createWorkbook(new File("d:/test.xls"));
            
/** *//** **********创建工作表************ */
            WritableSheet sheet 
= workbook.createSheet("工作表名称"0);

            
/** *//** *********设置列宽**************** */
            sheet.setColumnView(
015); // 第1列
            sheet.setColumnView(118); // 第2列
            sheet.setColumnView(213);
            sheet.setColumnView(
313);
            sheet.setColumnView(
415);
            sheet.setColumnView(
515);
            
//设置行高
            sheet.setRowView(0600false);
            sheet.setRowView(
1400false);
            sheet.setRowView(
7400false);
            
//设置页边距
            sheet.getSettings().setRightMargin(0.5);
            
//设置页脚
            sheet.setFooter("""""测试页脚");
            
/** *//** ************设置单元格字体************** */
            
//字体
            WritableFont NormalFont = new WritableFont(WritableFont.ARIAL, 10);
            WritableFont BoldFont 
= new WritableFont(WritableFont.ARIAL, 14,
                    WritableFont.BOLD);
            WritableFont tableFont 
= new WritableFont(WritableFont.ARIAL, 12,
                    WritableFont.NO_BOLD);
            WritableFont baodanFont 
= new WritableFont(WritableFont.ARIAL, 10,
                    WritableFont.BOLD);

            
/** *//** ************以下设置几种格式的单元格************ */
            
// 用于标题
            WritableCellFormat wcf_title = new WritableCellFormat(BoldFont);
            wcf_title.setBorder(Border.NONE, BorderLineStyle.THIN); 
// 线条
            wcf_title.setVerticalAlignment(VerticalAlignment.CENTRE); // 垂直对齐
            wcf_title.setAlignment(Alignment.CENTRE); // 水平对齐
            wcf_title.setWrap(true); // 是否换行

            
// 用于表格标题
            WritableCellFormat wcf_tabletitle = new WritableCellFormat(
                    tableFont);
            wcf_tabletitle.setBorder(Border.NONE, BorderLineStyle.THIN); 
// 线条
            wcf_tabletitle.setVerticalAlignment(VerticalAlignment.CENTRE); // 垂直对齐
            wcf_tabletitle.setAlignment(Alignment.CENTRE); // 水平对齐
            wcf_tabletitle.setWrap(true); // 是否换行

            
// 用于正文左
            WritableCellFormat wcf_left = new WritableCellFormat(NormalFont);
            wcf_left.setBorder(Border.ALL, BorderLineStyle.THIN); 
// 线条
            wcf_left.setVerticalAlignment(VerticalAlignment.CENTRE); // 垂直对齐
            wcf_left.setAlignment(Alignment.LEFT);
            wcf_left.setWrap(
true); // 是否换行

            
// 用于正文左
            WritableCellFormat wcf_center = new WritableCellFormat(NormalFont);
            wcf_center.setBorder(Border.ALL, BorderLineStyle.THIN); 
// 线条
            wcf_center.setVerticalAlignment(VerticalAlignment.CENTRE); // 垂直对齐
            wcf_center.setAlignment(Alignment.CENTRE);
            wcf_center.setWrap(
true); // 是否换行

            
// 用于正文右
            WritableCellFormat wcf_right = new WritableCellFormat(NormalFont);
            wcf_right.setBorder(Border.ALL, BorderLineStyle.THIN); 
// 线条
            wcf_right.setVerticalAlignment(VerticalAlignment.CENTRE); // 垂直对齐
            wcf_right.setAlignment(Alignment.RIGHT);
            wcf_right.setWrap(
false); // 是否换行

            
// 用于跨行
            WritableCellFormat wcf_merge = new WritableCellFormat(NormalFont);
            wcf_merge.setBorder(Border.ALL, BorderLineStyle.THIN); 
// 线条
            wcf_merge.setVerticalAlignment(VerticalAlignment.TOP); // 垂直对齐
            wcf_merge.setAlignment(Alignment.LEFT);
            wcf_merge.setWrap(
true); // 是否换行

            WritableCellFormat wcf_table 
= new WritableCellFormat(NormalFont);
            wcf_table.setBorder(Border.ALL, BorderLineStyle.THIN); 
// 线条
            wcf_table.setVerticalAlignment(VerticalAlignment.CENTRE); // 垂直对齐
            wcf_table.setAlignment(Alignment.CENTRE);
            wcf_table.setBackground(Colour.GRAY_25);
            wcf_table.setWrap(
true); // 是否换行

            
/** *//** ************单元格格式设置完成****************** */
            
//合并单元格,注意mergeCells(col0,row0,col1,row1) --列从0开始,col1为你要合并到第几列,行也一样
            sheet.mergeCells(0050);

            sheet.addCell(
new Label(00"这里是大标题,自定义格式",
                    wcf_title));

            sheet.mergeCells(
0111);
            sheet.mergeCells(
2151);

            sheet.addCell(
new Label(01"", wcf_center));
            sheet.addCell(
new Label(21"姓名:" + "supercrsky",
                    wcf_center));

            sheet.mergeCells(
0212);
            sheet.mergeCells(
2232);

            sheet.addCell(
new Label(02"单位:", wcf_center));
            sheet.addCell(
new Label(22"ChinaLong", wcf_center));
            sheet.addCell(
new Label(42"薪水", wcf_center));
            sheet.addCell(
new Label(52"5000", wcf_center));

            sheet.mergeCells(
0313);
            sheet.mergeCells(
2333);

            sheet.addCell(
new Label(03"性别:", wcf_center));
            sheet.addCell(
new Label(23"", wcf_center));
            sheet.addCell(
new Label(43"婚否:", wcf_center));
            sheet.addCell(
new Label(53"", wcf_center));

            sheet.mergeCells(
0414);
            sheet.mergeCells(
2434);

            sheet.addCell(
new Label(04"是否在职:", wcf_center));
            sheet.addCell(
new Label(24,"",
                    wcf_center));
            sheet.addCell(
new Label(44,"工作经验:", wcf_center));
            sheet.addCell(
new Label(54"4",wcf_center));

            sheet.mergeCells(
0515);
            sheet.mergeCells(
2535);

            sheet.addCell(
new Label(05"保险费:", wcf_center));
            sheet.addCell(
new Label(25,"50",
                    wcf_center));
            sheet.addCell(
new Label(45"保险金额:", wcf_center));
            sheet.addCell(
new Label(55"50000",
                    wcf_center));

            sheet.mergeCells(
0616);
            sheet.mergeCells(
2636);

            sheet.addCell(
new Label(06"工作地点:", wcf_center));
            sheet.addCell(
new Label(26"北京", wcf_center));
            sheet.addCell(
new Label(46"开心度:", wcf_center));
            sheet.addCell(
new Label(56"一般", wcf_center));

            
// 另起一table
            sheet.mergeCells(0757);
            sheet.addCell(
new Label(07"详细数据", wcf_tabletitle));
            
// table标题
            sheet.addCell(new Label(08"序号", wcf_table));
            sheet.addCell(
new Label(18"姓名", wcf_table));
            sheet.addCell(
new Label(28"年龄", wcf_table));
            sheet.addCell(
new Label(38"性别", wcf_table));
            sheet.addCell(
new Label(48"婚否", wcf_table));
            sheet.addCell(
new Label(58"在职", wcf_table));
            
// table内容
            
//这里用你的dao
            TestDAO dao = new TestDAO();
            List list 
= dao.findBy(user.getUserId());
            System.out.println(
"此保单拥有防疫码数量:" + list.size());
            
for (int i = 0; i < list.size(); i++)
            
{
                
//对应你的vo类
                User data = (User) list.get(i);

                sheet.addCell(
new Label(09 + i, String.valueOf(i + 1),
                        wcf_center));
                sheet.addCell(
new Label(19 + i, data.getDlEPCode(),
                        wcf_center));
                sheet
                        .addCell(
new Label(29 + i, data.getDlType(),
                                wcf_center));
                sheet.addCell(
new Label(39 + i, String.valueOf(data
                        .getDlPigAge()), wcf_center));
                sheet.addCell(
new Label(49 + i, "", wcf_center));
                sheet.addCell(
new Label(59 + i, "", wcf_center));
            }

            
/** *//** **********以上所写的内容都是写在缓存中的,下一句将缓存的内容写到文件中******** */
            workbook.write();
            
/** *//** *********关闭文件************* */
            workbook.close();
            System.out.println(
"导出成功");
            
// 存放url地址
        }
 catch (Exception e)
        
{
            System.out.println(
"在输出到EXCEL的过程中出现错误,错误原因:" + e.toString());
        }

    }

完整源码可以在这里下载
分享到:
评论

相关推荐

    jxl(jExcelAPI)的基本使用方法

    jxl(jExcelAPI)的基本使用方法

    jexcelapi

    《使用JExcelAPI进行Excel操作的深度解析》 在Java编程中,处理Excel文件是一项常见的任务,无论是数据导入导出,还是报表生成,都离不开对Excel的读写操作。JExcelAPI,作为一个强大的开源库,为Java开发者提供了...

    jexcelapi_2_4.tar.gz_java项目_jexcelapi_2_4_jexcelapi_2_4-2.tar._j

    对于Java开发者来说,掌握JExcelAPI的使用技巧,能极大地提升工作效率,减少与Excel打交道时的繁琐过程。 总之,JExcelAPI作为Java操作Excel的利器,通过其丰富的API和强大的功能,使得在Java项目中处理Excel文件变...

    jexcelapi_2_5

    本文将深入探讨JExcelAPI 2.5的核心特性、使用方法以及如何在实际项目中发挥其潜力。 一、JExcelAPI 2.5简介 JExcelAPI 2.5提供了对Excel文件的强大读写支持,允许开发者无需借助Microsoft Office或其他第三方工具...

    jexcelapi.rar

    《使用Java操作Excel:JExcelApi深度解析》 在数据处理和分析的领域中,Excel是一种广泛使用的工具,尤其在企业级应用中,其强大的表格处理能力得到了充分的认可。然而,当涉及到程序化操作或者集成到自动化流程时...

    jexcelapi_2_6_6.tar.gz

    要使用JExcelAPI 2.6.6,首先需要下载对应的jar包,将其加入到项目的类路径中。对于Maven项目,可以在pom.xml文件中添加如下依赖: ```xml &lt;groupId&gt;net.sourceforge.jexcelapi&lt;/groupId&gt; &lt;artifactId&gt;jxl ...

    jexcelapi_2_4_3.tar.gz

    在项目中使用jExcelApi,首先需要将其jar包引入。"jexcelapi_2_4_3.tar.gz"文件是一个压缩包,包含了jExcelApi的库文件。解压后,将得到的jar包添加到项目的类路径中,或者通过Maven或Gradle等构建工具进行管理。 ...

    jexcelapi 2.6.6

    4. **高性能和灵活性**:JExcelApi的API设计简洁明了,易于学习和使用,同时提供了丰富的功能,使得开发者可以根据需求灵活地处理Excel文件,提高开发效率。 5. **公式处理**:JExcelApi可以识别并计算Excel中的...

    java 利用jexcelapi操作Excel

    在你的项目中,你需要将这个jar文件添加到类路径(classpath)中,以便能够使用JExcelAPI提供的各种功能。`.classpath`文件通常用于Eclipse这样的IDE,它记录了项目的类路径设置,确保编译和运行时能正确加载依赖的...

    JExcelAPI与Apache POI两者对比

    JExcelAPI与Apache POI两者对比

    jexcelapi_2_6_12.zip

    三、JExcelAPI使用示例 以下是一个简单的使用JExcelAPI读取和写入Excel文件的例子: ```java import jxl.*; // 读取Excel文件 Workbook workbook = Workbook.getWorkbook(new File("input.xls")); Sheet sheet = ...

    jexcelapi_2_6_12

    以下是一个简单的使用jExcelAPI写入Excel文件的示例: ```java import jxl.*; public class JExcelExample { public static void main(String[] args) throws Exception { Workbook workbook = Workbook....

    jexcelapi jxl

    jexcelapi的API jxl的API 源码

    jexcelapi,java操作Excel表jar包

    - `jxl.jar`:这是jExcelAPI的核心库文件,包含了所有的类和方法,导入到项目中就可以使用jExcelAPI的功能。 - `docs`:通常包含库的文档,可能有API参考、用户指南、示例代码等,对于理解和使用jExcelAPI非常有帮助...

    jexcelapi-包

    2. **写入Excel文件**:同样,我们也可以使用jexcelapi创建新的Excel文件或向已有的文件写入数据。创建新工作簿的方法是`Workbook.createWorkbook(File file)`,添加工作表使用`Workbook.addSheet(String sheetName)...

    jexcelapi_2_6_6

    6. **API简化**:jExcelAPI提供了易于使用的API,使得开发者可以快速上手,编写与Excel交互的代码。 **使用示例** ```java // 创建一个新的工作簿 WritableWorkbook workbook = Workbook.createWorkbook(new File...

    JExcelAPI

    JExcelAPI java 用于操作excel的一些API JAr包

Global site tag (gtag.js) - Google Analytics