我是靠谱客的博主 平常香菇,这篇文章主要介绍Android向Excel写入数据导出U盘并发送邮件,现在分享给大家,希望可以做个参考。

本文实例为大家分享了Android向Excel写入数据导出并发送邮件的具体代码,供大家参考,具体内容如下

创建Execl、写入Excel格式

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
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 */ 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(); 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(); } }; //删除文件夹 private void deleteExcel(File file){ if(file.exists()){ file.delete(); } }

检测U盘、制作Excel表格

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
private void postEmail(String emailPath){   SimpleDateFormat fmat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");   String time=fmat.format(new Date(System.currentTimeMillis()));   String path=getExcelDir()+ File.separator+"IdCardInfo.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, "请选择邮件发送软件"));   } }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持靠谱客。

最后

以上就是平常香菇最近收集整理的关于Android向Excel写入数据导出U盘并发送邮件的全部内容,更多相关Android向Excel写入数据导出U盘并发送邮件内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(122)

评论列表共有 0 条评论

立即
投稿
返回
顶部