Android 将数据写入Execl格式导出U盘、发送邮件
创建Execl、写入Execl数据、导入U盘
public WriteExcel(Context mContext){
    this.mContext = mContext;
}
// 创建excel表
public void createExcel(File file) {
    deleteExcel(file);
    WritableSheet ws = null;
    try {
        if (!file.exists()) {
            wwb = Workbook.createWorkbook(file);//创建表
            ws = wwb.createSheet("sheet1", 0);//表名 页数
            // 在指定单元格插入数据
            Label lbl1 = new Label(0, 0, "标签1");
            Label lbl2 = new Label(1, 0, "标签2");
            Label lbl3 = new Label(2, 0, "标签3");
            Label lbl4 = new Label(3, 0, "标签4");
            ws.addCell(lbl1);
            ws.addCell(lbl2);
            ws.addCell(lbl3);
            ws.addCell(lbl4);
            // 从内存中写入文件中
            wwb.write();
            wwb.close();
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
}
 /**向Execl写入数据
     * @Param ls List<map>数据
     * @Param emeailPath 邮箱地址
     * @Param file 写入的路径,比如U盘路径
     */
public void writeToExcel(List<Map<String,Object>> ls,String emeailPath,File file) {
    try {
        Workbook oldWwb = Workbook.getWorkbook(file);
        wwb = Workbook.createWorkbook(file, oldWwb);
        WritableSheet ws = wwb.getSheet(0);
        // 当前行数
        for (int i = 0; i < ls.size(); i++) {
            int row = ws.getRows();
            Label lab1 = new Label(0, row, ls.get(i).get("数据1") + "");
            Label lab2 = new Label(1, row, ls.get(i).get("数据2") + "");
            Label lab3 = new Label(2, row, ls.get(i).get("数据3") + "");
            Label lab4 = new Label(3, row, ls.get(i).get("数据4") + "");
            ws.addCell(lab1);
            ws.addCell(lab2);
            ws.addCell(lab3);
            ws.addCell(lab4);
        }
            wwb.write();
            wwb.close();
           //判断是写入U盘还是发送邮件
            if (emeailPath != null) {
                postEmail(emeailPath);
            }else{
                final ProgressDialog precentDialog=new  ProgressDialog(mContext);
                precentDialog.setMessage("导出U盘中...");
                precentDialog.setMax(100);
                precentDialog.setCanceledOnTouchOutside(false);
                precentDialog.show();
                new Thread(){
                    public void run() {
                        //等待进度条
                        for (int i = 0; i < 100; i++) {
                            try {
                                long l= (long) (Math.random()*200);
                                Thread.sleep(l);
                            } catch (InterruptedException e) {
                                e.printStackTrace();
                            }
                            precentDialog.setProgress(i);
                        }
                        precentDialog.dismiss();
                        handler.sendEmptyMessage(1);
                    };
                }.start();
            }
    }catch(Exception e){
        e.printStackTrace();
    }
}
@SuppressLint("HandlerLeak")
private Handler handler = new android.os.Handler() {
    @Override
    public void handleMessage(Message msg) {
        // TODO Auto-generated method stub
        super.handleMessage(msg);
        Toast.makeText(mContext,"导入U盘完成!",Toast.LENGTH_SHORT).show();
    }
};
// 获取Excel文件夹
public static String getExcelDir() {
    // SD卡指定文件夹
    String sdcardPath = Environment.getExternalStorageDirectory()
            .toString();
    File dir = new File(sdcardPath + File.separator + "Excel");
    if (dir.exists()) {
        return dir.toString();
    } else {
        dir.mkdirs();
        Log.e("BAG", "保存路径不存在,");
        return dir.toString();
    }
}
//删除文件夹
private void deleteExcel(File file){ if(file.exists()){ file.delete(); } }    
发送带附件的邮件
private void postEmail(String emailPath){
  SimpleDateFormat fmat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  String time=fmat.format(new Date(System.currentTimeMillis()));
  //打开execl文件
  String path=getExcelDir()+ File.separator+"CardInfo.xls";
  File file = new File(path);
  if(file.exists()){
      Intent email = new Intent(android.content.Intent.ACTION_SEND);
      email.setType("application/octet-stream");
      //邮件接收者(数组,可以是多位接收者)
      String[] emailReciver = new String[]{emailPath};
      String  emailTitle = "信息_"+time;
      String emailContent = "核验信息";
      //设置邮件地址
      email.putExtra(android.content.Intent.EXTRA_EMAIL, emailReciver);
      //设置邮件标题
      email.putExtra(android.content.Intent.EXTRA_SUBJECT, emailTitle);
      //设置发送的内容
      email.putExtra(android.content.Intent.EXTRA_TEXT, emailContent);
      //附件
      email.putExtra(Intent.EXTRA_STREAM, Uri.fromFile(file));
      //调用系统的邮件系统
      mContext.startActivity(Intent.createChooser(email, "请选择邮件发送软件"));
  }
}
邮箱格式检查的正则表达式
public static final String REGEX_EMAIL = "^([a-z0-9A-Z]+[-|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$";
Android 将数据写入Execl格式导出U盘、发送邮件的更多相关文章
- Python数据写入csv格式文件
		(只是传递,基础知识也是根基) Python读取数据,并存入Excel打开的CSV格式文件内! 这里需要用到bs4,csv,codecs,os模块. 废话不多说,直接写代码!该重要的内容都已经注释了, ... 
- python 将json格式的数据写入csv格式的文件中
		# coding=utf-8 import json import csv # 重新进行配置读写数据时的默认编码 import sys reload(sys) sys.setdefaultencodi ... 
- Python基础-数据写入execl
		import xlwt book = xlwt.Workbook()#创建一个excel sheet = book.add_sheet('lanxia')#添加一个sheet页 title = ['姓 ... 
- 利用NPOI导出数据到Execl
		相信很多童鞋都开发过Execl的导入导出功能,最近产品中无论是后台数据分析的需要,还是前端满足用户管理的方便,都有Execl导入导出的维护需求产生. 以前做这个功能,如果是web,利用HttpCont ... 
- (原创)将Datatable数据按照Excel模板格式导出
		最近遇到一个问题,就是导出数据的时候需要自定义的表头,如图 如果自己用代码写表头的话,可能会有点复杂,而且代码量很多,所以我就想了一个办法,直接在Excel里面把表头定义好,然后把数据写入Excel模 ... 
- java将数据写入到txt文件中(txt有固定的格式)
		java将数据写入到txt文件中,这个应该对于学过java I/O的人来说是很简单的事情了,但是如果要将数据以固定的格式写入到txt文件中,就需要一定的技巧了. 这里举个简单的例子,以供参考: 比如我 ... 
- 带格式导出数据到Excel
		导出按钮事件 protected void Button1_Click(object sender, EventArgs e) { Response.Clear(); ... 
- Python3 Pandas的DataFrame格式数据写入excle文件、json、html、剪贴板、数据库
		Python3 Pandas的DataFrame格式数据写入excle文件.json.html.剪贴板.数据库 一.DataFrame格式数据 Pandas是Python下一个开源数据分析的库,它提供 ... 
- PL/SOL csv格式导出查询结果时出现某些列的数据被四舍五入了的解决办法
		昨天用pl/sql从oracle数据库捞取数据时,发现导出的csv格式中某些列的数据被进行了四舍五入处理了,当然这些列都是纯数字的,百思不得其解,后来上网才,才得知了原因. 这并不是导出的CSV文件数 ... 
随机推荐
- [CocoaPods]使用CocoaPods
			将Pod添加到Xcode项目中 在你开始之前 检查Specs存储库或cocoapods.org以确保您要使用的库可用. 在您的计算机上安装CocoaPods. 安装 创建Podfile,并添加依赖项: ... 
- Python函数学习——初步认识
			函数使用背景 假设老板让你写一个监控程序,24小时全年无休的监控你们公司网站服务器的系统状况, 当cpu\memory\disk等指标的使用量超过阀值时即发邮件报警, 你掏空了所有的知识量,写出了以下 ... 
- Java学习之Servlet篇
			<JAVA遇见HTML——Servlet篇> Servlet 生命周期:Servlet 加载--->实例化--->服务--->销毁. init():在Servlet的生命 ... 
- appium-doctor
			1. I installed appium-1.5.3.dmg But when I click the stethoscope button the Appium is show error : ... 
- GO入门——6. struct与方法
			1 struct Go 中的struct与C中的struct非常相似,并且Go没有class 使用 type struct{} 定义结构,名称遵循可见性规则 支持指向自身的指针类型成员 支持匿名结构, ... 
- Emgucv学习系列之环境搭建
			Emgucv功能介绍 Emgucv是跨平台的,是Opencv的.net版本.可以对图片.视频等多媒体资源进行加工处理的SDK库. Emgucv下载和安装SDK 下载地址:https://sourcef ... 
- 【Java基本功】一文读懂String及其包装类的实现原理
			String作为Java中最常用的引用类型,相对来说基本上都比较熟悉,无论在平时的编码过程中还是在笔试面试中,String都很受到青睐,然而,在使用String过程中,又有较多需要注意的细节之处. S ... 
- div盒子水平垂直居中方法
			文章转载自:div盒子水平垂直居中的方法 - 雪明瑶 这个问题比较老,方法比较多,各有优劣,着情使用. 一.盒子没有固定的宽和高 方案1.Transforms 变形 这是最简单的方法,不仅能实现绝对居 ... 
- 解决Windows英文版中文软件乱码的问题
			由于工作的原因,我们的开发环境都是基于英文的,但是在打开一些基于中文编码的软件的时候经常会出现乱码的情况.其实只要打开控制面板按照下面的步骤稍微设置一下,就可以完美的在英文操作系统下支持中文软件了,因 ... 
- 自己动手实现java数据结构(一) 向量
			1.向量介绍 计算机程序主要运行在内存中,而内存在逻辑上可以被看做是连续的地址.为了充分利用这一特性,在主流的编程语言中都存在一种底层的被称为数组(Array)的数据结构与之对应.在使用数组时需要事先 ... 
