创建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盘、发送邮件的更多相关文章

  1. Python数据写入csv格式文件

    (只是传递,基础知识也是根基) Python读取数据,并存入Excel打开的CSV格式文件内! 这里需要用到bs4,csv,codecs,os模块. 废话不多说,直接写代码!该重要的内容都已经注释了, ...

  2. python 将json格式的数据写入csv格式的文件中

    # coding=utf-8 import json import csv # 重新进行配置读写数据时的默认编码 import sys reload(sys) sys.setdefaultencodi ...

  3. Python基础-数据写入execl

    import xlwt book = xlwt.Workbook()#创建一个excel sheet = book.add_sheet('lanxia')#添加一个sheet页 title = ['姓 ...

  4. 利用NPOI导出数据到Execl

    相信很多童鞋都开发过Execl的导入导出功能,最近产品中无论是后台数据分析的需要,还是前端满足用户管理的方便,都有Execl导入导出的维护需求产生. 以前做这个功能,如果是web,利用HttpCont ...

  5. (原创)将Datatable数据按照Excel模板格式导出

    最近遇到一个问题,就是导出数据的时候需要自定义的表头,如图 如果自己用代码写表头的话,可能会有点复杂,而且代码量很多,所以我就想了一个办法,直接在Excel里面把表头定义好,然后把数据写入Excel模 ...

  6. java将数据写入到txt文件中(txt有固定的格式)

    java将数据写入到txt文件中,这个应该对于学过java I/O的人来说是很简单的事情了,但是如果要将数据以固定的格式写入到txt文件中,就需要一定的技巧了. 这里举个简单的例子,以供参考: 比如我 ...

  7. 带格式导出数据到Excel

    导出按钮事件 protected void Button1_Click(object sender, EventArgs e)    {        Response.Clear();        ...

  8. Python3 Pandas的DataFrame格式数据写入excle文件、json、html、剪贴板、数据库

    Python3 Pandas的DataFrame格式数据写入excle文件.json.html.剪贴板.数据库 一.DataFrame格式数据 Pandas是Python下一个开源数据分析的库,它提供 ...

  9. PL/SOL csv格式导出查询结果时出现某些列的数据被四舍五入了的解决办法

    昨天用pl/sql从oracle数据库捞取数据时,发现导出的csv格式中某些列的数据被进行了四舍五入处理了,当然这些列都是纯数字的,百思不得其解,后来上网才,才得知了原因. 这并不是导出的CSV文件数 ...

随机推荐

  1. Spring Boot 配置随机数技巧

    Spring Boot支持在系统加载的时候配置随机数. 添加config/random.properties文件,添加以下内容: #随机32位MD5字符串 user.random.secret=${r ...

  2. Liferay平台开发使用详细PPT演示文稿

    主要章节: 概述 功能和使用 开发扩展 安全.认证 高可用 Demo 独立流程演示工程: Liferay集成Activiti开发工程: PPT演示文稿下载 Demo程序分2部分: 独立流程演示工程:h ...

  3. DefaultServlet

    在web访问任何资源都是在访问Servlet 当你启动Tomcat,你在网址上输入http://localhost:8080.为什么会出现Tomcat小猫的页面? 这是由缺省Servlet为你服务的! ...

  4. 不要再说我简历上Java项目都好low!【offer收割机必备】

    获取精品学习资料私信 欢迎加入QQ群架构华山论剑:836442475(大牛聚集地)一起交流学习探讨! 目录 高级工程师必备:系统设计能力 如何让你的项目更有技术含量 这篇文章我们继续来聊一聊,在系统设 ...

  5. linux中crontab的使用方法

    crontab参数说明: -e : 执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请先设定 VISUAL 环境变数来指定使用那个文字编辑器(比如说 setenv V ...

  6. [每天解决一问题系列 - 0012] 如何通过程序获取IIS站点信息

    问题描述: 在WiX中需要判断某个站点是否存在,WiX没有这个能力,该怎么做呢? 解决方案: 解决方法就是写一个Custom Action来检测,实现的途径也有很多,现在想到了这么几个 1)Power ...

  7. odoo开发笔记 -- 进入后台调试模式

    ./odoo-bin shell -d test1 -c /home/odoo/odooshare/odoo.conf ./odoo-bin shell -d 数据库名 -c 指定配置文件

  8. FF笔试题

    一.单选题 1.下列关于继承的描述错误的是(  ) A.  在Java中允许定义一个父类的引用,指向子类对象 B.  在Java中继承是通过extends关键字来描述的,而且只允许继承自一个直接父类 ...

  9. jar包版本介绍(beta,alpha,release),软件的版本介绍

    α(Alpha) 此版本表示该软件仅仅是一个初步完成品,通常只在软件开发者内部交流,也有很少一部分发布给专业测试人员.一般而言,该版本软件的bug(漏洞)较多,普通用户最好不要安装.主要是开发者自己对 ...

  10. Oracle的数据并发与一致性详解(上)

    今天想了解下oracle中事务与锁的原理,但百度了半天,发现网上介绍的内容要么太短,要么版本太旧,而且抄袭现象严重,所以干脆查官方帮助文档(oracle 11.2),并将其精华整理成中文,供大家一起学 ...