2018-03-31

package com.jokey.wisdomaldetection.utils;

import android.content.Context;
import android.os.Environment;
import android.util.Log;

import com.jokey.wisdomaldetection.R;
import com.jokey.wisdomaldetection.teble.TestDataTable;

import org.litepal.crud.DataSupport;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set;

import jxl.Workbook;
import jxl.format.Colour;
import jxl.format.UnderlineStyle;
import jxl.format.VerticalAlignment;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

/**
 * Created by Administrator on 2018/3/27.
 */

public class WriteToExcelUtils {

    private static List<TestDataTable> DataList;

    public static void saveFile(String fileName, Context context, int rawid) throws IOException {

        // 首先判断该目录下的文件夹是否存在
        File dir = new File(Environment.getExternalStorageDirectory() + "/Wisdom/");

        if (!dir.exists()) {
            // 文件夹不存在 , 则创建文件夹
            dir.mkdirs();
        }

        // 判断目标文件是否存在
        File file1 = new File(dir, fileName);

        if (!file1.exists()) {
            file1.createNewFile(); // 创建文件

        }
        // 开始进行文件的复制
        InputStream input = context.getResources().openRawResource(rawid); // 获取资源文件raw
        // 标号
        try {

            FileOutputStream out = new FileOutputStream(file1); // 文件输出流、用于将文件写到SD卡中
            // -- 从内存出去
            byte[] buffer = new byte[1024];
            int len = 0;
            while ((len = (input.read(buffer))) != -1) { // 读取文件,-- 进到内存

                out.write(buffer, 0, len); // 写入数据 ,-- 从内存出
            }

            input.close();
            out.close(); // 关闭流
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void printer(Context context) {
        try {
            saveFile("wisdom.xls", context, R.raw.wisdom);//文件目录res/raw


            String wisdomExcel = Environment.getExternalStorageDirectory() + "/wisdom/wisdom.xls";

            // 打开文件
            WritableWorkbook workbook = Workbook.createWorkbook(new File(wisdomExcel));

            Set date = new HashSet();

            DataList = DataSupport.findAll(TestDataTable.class);


            WritableSheet[] sheet=new WritableSheet[20];

            for(int i=0;i<DataList.size();i++){
                date.add(DataList.get(i).getMt().substring(0,11));
            }
            Iterator it = date.iterator();

            int k=0;

            while (it.hasNext()){
                sheet[k]=workbook.createSheet(String.valueOf(it.next()),k++);
            }


            /**
             * 自定义单元格
             * 定义格式 字体 下划线 斜体 粗体 颜色
             */
            WritableFont wf_title = new WritableFont(WritableFont.TIMES, 20, WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.RED);

            WritableCellFormat wcf_title = new WritableCellFormat(wf_title); // 单元格定义
            wcf_title.setBackground(jxl.format.Colour.BLACK); // 设置单元格的背景颜色
            wcf_title.setAlignment(jxl.format.Alignment.CENTRE); // 设置对齐方式
            //wcf_title.setBorder(jxl.format.Border.ALL, jxl.format.BorderLineStyle.MEDIUM, Colour.BLACK);


            /**
             * 自定义单元格
             * 定义格式 字体 下划线 斜体 粗体 颜色
             */
            WritableFont wf_center = new WritableFont(WritableFont.TIMES, 10, WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE, Colour.BLACK);

            WritableCellFormat wcf_center = new WritableCellFormat(wf_center); // 单元格定义
            wcf_center.setBackground(jxl.format.Colour.BLACK); // 设置单元格的背景颜色
            wcf_center.setAlignment(jxl.format.Alignment.CENTRE); // 水平居中
            wcf_center.setVerticalAlignment(VerticalAlignment.CENTRE);//竖直居中

            wcf_center.setBorder(jxl.format.Border.ALL, jxl.format.BorderLineStyle.MEDIUM, Colour.BLACK);





            /**
             * 添加基本样式
             */
            // 1.添加Label对象三个参数意思:【列,行,值】
            sheet[0].addCell(new Label(0, 0, "导杆压降测量结果", wcf_title)); // 普通的带有定义格式的单元格
            sheet[0].mergeCells(0, 0, 12, 1); // 标题合并单元格


            //添加日期
            sheet[0].addCell(new Label(1,2,"2018-3-31",wcf_center));//模拟插入槽号数值
            sheet[0].addCell(new Label(0,2,"测量日期",wcf_center));
            sheet[0].mergeCells(1, 2, 12, 2); // 槽号合并单元格


           //添加槽号
            sheet[0].addCell(new Label(1,3,"5120",wcf_center));//模拟插入槽号数值
            sheet[0].addCell(new Label(0,3,"槽号",wcf_center));
            sheet[0].mergeCells(1, 3, 12, 3); // 槽号合并单元格


            sheet[0].addCell(new Label(0,4,"A面",wcf_center));
            sheet[0].mergeCells(0, 4, 0, 5); // A面合并单元格
            for(int i=0;i<12;i++){
                sheet[0].addCell(new Label(i+1,4,""+(i+1),wcf_center));
                //模拟插入数据
                sheet[0].addCell(new Label(i+1,4+1,""+(i+500),wcf_center));

            }

            sheet[0].addCell(new Label(0,6,"B面",wcf_center));
            sheet[0].mergeCells(0, 6, 0, 7); // B面合并单元格
            for(int i=0;i<12;i++){
                sheet[0].addCell(new Label(i+1,6,""+(i+1),wcf_center));
                //模拟插入数据
                sheet[0].addCell(new Label(i+1,6+1,""+(i+500),wcf_center));

            }









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

            //Toast.makeText(this,"保存成功",Toast.LENGTH_SHORT).show();
            Log.i("jokeyWriteToExcel","Excel---保存成功");
            //以下代码是连接打印机的,这边没有用到,所以可以忽略


        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            Log.i("jokeyWriteToExcel","excel失败---"+e.toString());

        }
    }
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容