美文网首页
2018-03-31

2018-03-31

作者: ProZoom | 来源:发表于2018-03-31 19:14 被阅读3次
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());

        }
    }
}

相关文章

网友评论

      本文标题:2018-03-31

      本文链接:https://www.haomeiwen.com/subject/xrkncftx.html