这周水了几天,今天把博客赶上,找找状态。

  周五的时候终于完成了课堂测试第二阶段,主要的难点就是生成Excel表并将填写的数据插入到Excel表中。

一.jxl使用

1、创建或读取一个工作薄 Workbook
 
创建一个工作薄,就是整个Excel文档,
         WritableWorkbook wwb = Workbook.createWorkbook(os);
其中os为一个文件输出流。当然还有很多其他的入参,比如File等。
 
Workbook不但能用来创建工作薄,也可以读取现有的工作薄,比如:
         Workbook.getWorkbook(java.io.File file);
Workbook是一个很重要工具类,里面方法基本上都是static的,使用方便。
 
2、创建工作表 Sheet
 
创建工作表的方式是通过上面创建的WritableWorkbook对象来操作。
创建一个工作表:
         createSheet(java.lang.String name, int index),
两个参数分别是工作表名字和插入位置,这个位置从0开始,比如:
         WritableSheet sheet = wwb.createSheet("演员表", 0);
 
3、创建标签 Label
 
实际上标签这里的意思就是工作表的单元格,这个单元格多种,分别对应不同的类,比如jxl.write.Boolean、jxl.write.Boolean等。
         Label label = new Label(col, row, title); 
三个参数分别表示col+1列,row+1行,标题内容是title。
 
将标签加入到工作表中
         sheet.addCell(label);
 
4、填充数据
 
数据填充这块稍微复杂点,涉及到数据单元格的格式问题。
 
a)、填充数字
        jxl.write.Number numb = new jxl.write.Number(1, 1, 250); 
        sheet.addCell(numb);
 
b)、填充格式化的数字
        jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.##"); 
        jxl.write.WritableCellFormat wcf = new jxl.write.WritableCellFormat(nf); 
        jxl.write.Number n = new jxl.write.Number(2, 1, 2.451, wcf); 
        sheet.addCell(n);
 
c)、填充日期
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 
        String newdate = sdf.format(new Date()); 
        label = new Label(2, 2, newdate); 
        sheet.addCell(label);
 
d)、填充文本
        label = new Label(3, 3, "周星驰"); 
        sheet.addCell(label);
 
e)、填充boolean值
        jxl.write.Boolean bool = new jxl.write.Boolean(4, 1, true); 
        sheet.addCell(bool);
 
5、合并单元格
 
 通过writablesheet.mergeCells(int x,int y,int m,int n);来实现的。
 表示将从第x+1列,y+1行到m+1列,n+1行合并 (四个点定义了两个坐标,左上角和右下角)
 结果是合并了m-x+1行,n-y+1列,两者乘积就是合并的单元格数量。
 
        sheet.mergeCells(0, 6, 3, 8); 
        label = new Label(0, 6, "合并了12个单元格"); 
        sheet.addCell(label);
 
6、添加单元格的式样
 
主要是改变单元格背景、字体、颜色等等。
        WritableCellFormat wc = new WritableCellFormat(); 
        // 设置居中 
        wc.setAlignment(Alignment.CENTRE); 
        // 设置边框线 
        wc.setBorder(Border.ALL, BorderLineStyle.THIN); 
        // 设置单元格的背景颜色 
        wc.setBackground(jxl.format.Colour.RED); 
        label = new Label(1, 5, "字体", wc); 
        sheet.addCell(label);
 
7、设置单元格字体
 
        // 设置字体 
        jxl.write.WritableFont wfont = new jxl.write.WritableFont(WritableFont.createFont("楷书"), 20); 
        WritableCellFormat font = new WritableCellFormat(wfont); 
        label = new Label(2, 6, "楷书", font); 
        sheet.addCell(label);
 
8、将工作写成文件
 
        // 写入数据 
        wwb.write(); 
        // 关闭文件 
        wwb.close(); 
 
9、行列的批量操作
 
        //获取所有的工作表 
        jxl.write.WritableSheet[] sheetList = wwb.getSheets(); 
        //获取第1列所有的单元格 
        jxl.Cell[] cellc = sheet.getColumn(0); 
        //获取第1行所有的单元格 
        jxl.Cell[] cellr = sheet.getRow(0); 
        //获取第1行第1列的单元格 
        Cell c = sheet.getCell(0, 0);
 
10、获取单元格的值
 
        //获取单元格的值,不管什么单元格,返回都是字符串

String value = c.getContents();

二.插入数据

  思路是在userservice层写好查询方法,在activity中实例化对象,调用方法。

转自http://liuxiangdong100.blog.163.com/blog/static/2261943820106198363739/

android开发使用jxl创建Excel的更多相关文章

  1. Jxl创建Excel文件和解析Excel文件

    import java.io.File; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; im ...

  2. Android开发-API指南-创建 Content Provider

    Creating a Content Provider 英文原文:http://developer.android.com/guide/topics/providers/content-provide ...

  3. Android基础之用Eclipse搭建Android开发环境和创建第一个Android项目(Windows平台)

    一.搭建Android开发环境 准备工作:下载Eclipse.JDK.Android SDK.ADT插件 下载地址:Eclipse:http://www.eclipse.org/downloads/ ...

  4. Android开发,Eclipse创建aidl接口时,出错

    Android开发中,当我们需要调用远程Service时,我们一般通过远程接口(RMI)来实现的,而Android的RMI需要AIDL(Android Interface Definition Lan ...

  5. [.NET开发] C# 如何创建Excel多级分组

    要设置显示或者隐藏分类数据下的详细信息,在便于数据查看.管理的同时也使文档更具美观性.那么,在C#中如何来创建Excel数据的多级分组显示呢?下面将进行详细阐述.方法中使用了免费版组件Free Spi ...

  6. jxl 创建excel

    public static void performanceExcel(String sCurrPath,List<Record> list, String begin,String en ...

  7. Android开发--Activity的创建

    1.Activity概述 Activity是android四大基本组件之一.每一个activity文件对应一个界面,一个程序由多个activity组成. 2.Android工作目录

  8. Android开发 MMS支持 创建和编辑MMS

    Composing and editing MMS在Android Mms 应用里面的具体实现形式,或数据结构是SlideshowModel,它是一个每个节点为SlideModel的 ArrayLis ...

  9. Android开发系列之创建自定义控件

    Android开发过程中我们经常需要定义自己的控件,一方面基于复用的角度考虑,一方面也是基于逻辑处理思维的角度考虑.在这篇博客里面,笔者想要介绍.总结几种Android自定义控件的方法,如果有什么不对 ...

随机推荐

  1. 算法竞赛中的常用JAVA API:PriorityQueue(优先队列)(转载)

    算法竞赛中的常用JAVA API:PriorityQueue(优先队列) PriorityQueue 翻译过来就是优先队列,本质是一个堆, 默认情况下堆顶每次都保留最小值,每插入一个元素,仍动态维护堆 ...

  2. CircuitBreaker断路器Fallback如何获取异常

    在Spring Cloud 2020新版里, 可以使用新版的 CircuitBreaker 断路器, 可以配置Fallback, 可以是内部的, 也可以是外部的Fallback. 内部 Fallbac ...

  3. 【笔记】sklearn中的SVM以及使用多项式特征以及核函数

    sklearn中的SVM以及使用多项式特征以及核函数 sklearn中的SVM的使用 SVM的理论部分 需要注意的是,使用SVM算法,和KNN算法一样,都是需要做数据标准化的处理才可以,因为不同尺度的 ...

  4. Maven 下载、安装与配置

    一.需要准备的东西 确定电脑上已经成功安装JDK 二.下载与安装 1. 前往https://maven.apache.org/download.cgi下载最新版的Maven程序: 注意:Maven3. ...

  5. Mysql生成UUID的SQL语句

    大写的UUID: SELECT UPPER(UUID()); 小写的UUID: SELECT LOWER(UUID()); SELECT UUID(); 去掉横杠的UUID: SELECT REPLA ...

  6. TypeScript 入门指南 【大白话】

    前言 聊聊为何要学习TypeScript? 从开发角度来讲, TypeScript 作为强类型语言,对属性有类型约束.在日常开发中少了减少了不必要的因参数类型造成的BUG,当你在使用同事封装好的函数时 ...

  7. 如何修改leaflet的marker图标

    1. 从官网中查看对应文档:https://leafletjs.com/ 2. 3. var greenIcon = L.icon({ iconUrl: 'leaf-green.png', shado ...

  8. Qt元对象和属性系统详解

    Qt 是一个用标准 C++ 编写的跨平台开发类库,它对标准 C++ 进行了扩展,引入了元对象系统.信号与槽.属性等特性,使应用程序的开发变得更高效. 本节将介绍 Qt 的这些核心特点,对于理解和编写高 ...

  9. HttpClient4.3 教程 第五章 快速API

    5.1.Easy to use facade API HttpClient从4.2开始支持快速api.快速api仅仅实现了HttpClient的基本功能,它只要用于一些不需要灵活性的简单场景.例如,快 ...

  10. 深入浅出Mybatis系列(四)---配置详解之properties与environments

    我先简单的给大家示例一下properties的使用方法. <configuration> <!-- 方法一: 从外部指定properties配置文件, 除了使用resource属性指 ...