上次寫的那個對excel的操作,有讀和寫兩部分。不過還是不能滿足項目需求,然後今天做了一點點改進,就是不用自己寫的讀取表格,而是用別人寫好的程序來打開,然後查詢。
這裏就有一點,就是怎麼從程序中打開一個文件,這裏是打開excel文件,同理,還有別的文件打開問題,網上給出了兩個方案,我總結了下,我用的是第一種。我這裏是設計一個button鍵,然後跳轉到打開這個excel文件,用的是手機自帶的軟件。
/**
* 根據文件後綴名獲得對應的MIME類型。
* @param file
*/
private String getMIMEType(File file) {
String type="*/*";
String fName = file.getName();
//獲取後綴名前的分隔符"."在fName中的位置。
int dotIndex = fName.lastIndexOf(".");
if(dotIndex < 0){
return type;
}
/* 獲取文件的後綴名 */
String end=fName.substring(dotIndex,fName.length()).toLowerCase();
if(end=="")return type;
//在MIME和文件類型的匹配表中找到對應的MIME類型。
for(int i=0;i<MIME_MapTable.length;i++){ //MIME_MapTable??在這裏你一定有疑問,這個MIME_MapTable是什麼?
if(end.equals(MIME_MapTable[i][0]))
type = MIME_MapTable[i][1];
}
return type;
}
private final String[][] MIME_MapTable={
//{後綴名, MIME類型}
{".3gp", "video/3gpp"},
{".apk", "application/vnd.android.package-archive"},
{".asf", "video/x-ms-asf"},
{".avi", "video/x-msvideo"},
{".bin", "application/octet-stream"},
{".bmp", "image/bmp"},
{".c", "text/plain"},
{".class", "application/octet-stream"},
{".conf", "text/plain"},
{".cpp", "text/plain"},
{".doc", "application/msword"},
{".docx", "application/vnd.openxmlformats-officedocument.wordprocessingml.document"},
{".xls", "application/vnd.ms-excel"},
{".xlsx", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"},
{".exe", "application/octet-stream"},
{".gif", "image/gif"},
{".gtar", "application/x-gtar"},
{".gz", "application/x-gzip"},
{".h", "text/plain"},
{".htm", "text/html"},
{".html", "text/html"},
{".jar", "application/java-archive"},
{".java", "text/plain"},
{".jpeg", "image/jpeg"},
{".jpg", "image/jpeg"},
{".js", "application/x-javascript"},
{".log", "text/plain"},
{".m3u", "audio/x-mpegurl"},
{".m4a", "audio/mp4a-latm"},
{".m4b", "audio/mp4a-latm"},
{".m4p", "audio/mp4a-latm"},
{".m4u", "video/vnd.mpegurl"},
{".m4v", "video/x-m4v"},
{".mov", "video/quicktime"},
{".mp2", "audio/x-mpeg"},
{".mp3", "audio/x-mpeg"},
{".mp4", "video/mp4"},
{".mpc", "application/vnd.mpohun.certificate"},
{".mpe", "video/mpeg"},
{".mpeg", "video/mpeg"},
{".mpg", "video/mpeg"},
{".mpg4", "video/mp4"},
{".mpga", "audio/mpeg"},
{".msg", "application/vnd.ms-outlook"},
{".ogg", "audio/ogg"},
{".pdf", "application/pdf"},
{".png", "image/png"},
{".pps", "application/vnd.ms-powerpoint"},
{".ppt", "application/vnd.ms-powerpoint"},
{".pptx", "application/vnd.openxmlformats-officedocument.presentationml.presentation"},
{".prop", "text/plain"},
{".rc", "text/plain"},
{".rmvb", "audio/x-pn-realaudio"},
{".rtf", "application/rtf"},
{".sh", "text/plain"},
{".tar", "application/x-tar"},
{".tgz", "application/x-compressed"},
{".txt", "text/plain"},
{".wav", "audio/x-wav"},
{".wma", "audio/x-ms-wma"},
{".wmv", "audio/x-ms-wmv"},
{".wps", "application/vnd.ms-works"},
{".xml", "text/plain"},
{".z", "application/x-compress"},
{".zip", "application/x-zip-compressed"},
{"", "*/*"}
};
這是別人的程序,我沒有修改,所以本文是轉載的啦,不算原創。
效果就是,按下跳轉button然後就跳轉到提示問你,選擇一個程序打開這個文件,你選擇自己安裝好的打開下就可以了。
方法二就是通過intent,然後打開別人的程序的包文件,這個如果是自己的程序打開自己的程序,很簡單,你知道主activity和包名,別人的你要用PackageInfo得到的想要啓動的應用的包名,然後纔行。這裏我不多寫了,給出我看到的一個別人的鏈接,不知道靠譜不。我沒測試,我保懷疑態度。(http://blog.csdn.net/xiezhenxiang/article/details/7608752)