Android向Excel寫入數(shù)據(jù)導(dǎo)出U盤并發(fā)送郵件
本文實例為大家分享了Android向Excel寫入數(shù)據(jù)導(dǎo)出并發(fā)送郵件的具體代碼,供大家參考,具體內(nèi)容如下
創(chuàng)建Execl、寫入Excel格式
public WriteExcel(Context mContext){
this.mContext = mContext;
}
// 創(chuàng)建excel表
public void createExcel(File file) {
deleteExcel(file);
WritableSheet ws = null;
try {
if (!file.exists()) {
wwb = Workbook.createWorkbook(file);//創(chuàng)建表
ws = wwb.createSheet("sheet1", 0);//表名 頁數(shù)
// 在指定單元格插入數(shù)據(jù)
Label lbl1 = new Label(0, 0, "標(biāo)簽1");
Label lbl2 = new Label(1, 0, "標(biāo)簽2");
Label lbl3 = new Label(2, 0, "標(biāo)簽3");
Label lbl4 = new Label(3, 0, "標(biāo)簽4");
ws.addCell(lbl1);
ws.addCell(lbl2);
ws.addCell(lbl3);
ws.addCell(lbl4);
// 從內(nèi)存中寫入文件中
wwb.write();
wwb.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
/**向Execl寫入數(shù)據(jù)
* @Param ls List<map>數(shù)據(jù)
* @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);
// 當(dāng)前行數(shù)
for (int i = 0; i < ls.size(); i++) {
int row = ws.getRows();
Label lab1 = new Label(0, row, ls.get(i).get("數(shù)據(jù)1") + "");
Label lab2 = new Label(1, row, ls.get(i).get("數(shù)據(jù)2") + "");
Label lab3 = new Label(2, row, ls.get(i).get("數(shù)據(jù)3") + "");
Label lab4 = new Label(3, row, ls.get(i).get("數(shù)據(jù)4") + "");
ws.addCell(lab1);
ws.addCell(lab2);
ws.addCell(lab3);
ws.addCell(lab4);
}
// 從內(nèi)存中寫入文件中,只能刷一次
wwb.write();
wwb.close();
if (emeailPath != null) {
postEmail(emeailPath);
}else{
final ProgressDialog precentDialog=new ProgressDialog(mContext);
precentDialog.setMessage("導(dǎo)出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,"導(dǎo)入U盤完成!",Toast.LENGTH_SHORT).show();
}
};
//刪除文件夾
private void deleteExcel(File file){
if(file.exists()){
file.delete();
}
}
檢測U盤、制作Excel表格
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");
//郵件接收者(數(shù)組,可以是多位接收者)
String[] emailReciver = new String[]{emailPath};
String emailTitle = "信息_"+time;
String emailContent = "核驗信息";
//設(shè)置郵件地址
email.putExtra(android.content.Intent.EXTRA_EMAIL, emailReciver);
//設(shè)置郵件標(biāo)題
email.putExtra(android.content.Intent.EXTRA_SUBJECT, emailTitle);
//設(shè)置發(fā)送的內(nèi)容
email.putExtra(android.content.Intent.EXTRA_TEXT, emailContent);
//附件
email.putExtra(Intent.EXTRA_STREAM, Uri.fromFile(file));
//調(diào)用系統(tǒng)的郵件系統(tǒng)
mContext.startActivity(Intent.createChooser(email, "請選擇郵件發(fā)送軟件"));
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android開發(fā)自學(xué)筆記(六):聲明權(quán)限和Activity
這篇文章主要介紹了Android開發(fā)自學(xué)筆記(六):聲明權(quán)限和Activity,本文是上一篇的補充,需要的朋友可以參考下2015-04-04
第三方開源Android TickPlusDrawable狀態(tài)可以通過動畫切換的按鈕
Android tickplusdrawable(TickPlusDrawable)是一個狀態(tài)可以通過動畫切換的按鈕,本文給大家分享第三方開源Android TickPlusDrawable狀態(tài)可以通過動畫切換的按鈕,感興趣的朋友一起學(xué)習(xí)吧2015-12-12
Android編程判斷網(wǎng)絡(luò)是否可用及調(diào)用系統(tǒng)設(shè)置項的方法
這篇文章主要介紹了Android編程判斷網(wǎng)絡(luò)是否可用及調(diào)用系統(tǒng)設(shè)置項的方法,涉及Android針對網(wǎng)絡(luò)連接的判定及屬性設(shè)置的調(diào)用,需要的朋友可以參考下2016-03-03
RecyclerView 源碼淺析測量 布局 繪制 預(yù)布局
這篇文章主要介紹了RecyclerView 源碼淺析測量 布局 繪制 預(yù)布局,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
Android 中使用EditText 點擊全選再次點擊取消全選功能
這篇文章主要介紹了Android 中使用EditText 點擊全選再次點擊取消全選功能,非常不錯,具有參考借鑒價值,需要的朋友參考下吧2016-12-12
FloatingActionButton增強版一個按鈕跳出多個按鈕第三方開源之FloatingActionButton
這篇文章主要介紹了FloatingActionButton增強版一個按鈕跳出多個按鈕第三方開源之FloatingActionButton 的相關(guān)資料,需要的朋友可以參考下2015-12-12
Android實現(xiàn)從網(wǎng)絡(luò)獲取圖片顯示并保存到SD卡的方法
這篇文章主要介紹了Android實現(xiàn)從網(wǎng)絡(luò)獲取圖片顯示并保存到SD卡的方法,涉及Android操作多媒體文件及系統(tǒng)硬件設(shè)備的相關(guān)技巧,需要的朋友可以參考下2015-12-12

