java代码怎么判断文件的格式是excel文件 正则表达式,如何判断文件名后缀是否为csv、xls、xlsx...

Java \u5982\u4f55\u4e0d\u533a\u5206\u5927\u5c0f\u5199\u5224\u65ad\u6587\u4ef6\u540e\u7f00\uff08.xls .XLS .Xls\u7b49\uff09\u662f\u4e0d\u662fexcel\u6587\u4ef6\uff1f

String reg = "(?i)^.*\\.xls$";
String str = "";
str.matches(reg);


\u5728input\u4e2d\u60f3\u8981\u83b7\u53d6\u4e0a\u4f20\u7684\u6587\u4ef6\u540d\uff0c\u90a3\u4e48onclick\u4e8b\u4ef6\u662f\u4e0d\u884c\u7684\uff0c\u56e0\u4e3a\u4e00\u70b9\u51fbinput\u90a3\u4e48onclick\u4e8b\u4ef6\u5c31\u6267\u884c\uff0c\u4f46\u662f\u8fd9\u65f6\u5019\u8fd8\u6ca1\u4e0a\u4f20\u5185\u5bb9\uff0c\u4f46\u662fonchange\u4e8b\u4ef6\u662f\u4e0a\u4f20\u5b8c\u6210\u540e\u624d\u6267\u884c\u7684\u4e8b\u4ef6
\u4ee5\u4e0b\u65b9\u6cd5\u5c31\u662f\u5224\u65ad\u662f\u5426\u662fexcel\u6587\u4ef6
var File=document.getElementById(\u201cfile\u201d);
var str=File.value;
1\u3001\u67e5\u627e\u5b57\u7b26\u4e32
if(str.indexOf("xls")<0&&str.indexOf("xlsx")<0)
{alert("\u8bf7\u9009\u62e9\u683c\u5f0f\u4e3a.xls\u6216.xlsx\u7684\u6587\u4ef6\uff01");return false;
}
2\u3001\u6b63\u5219\u8868\u8fbe\u5f0f\uff1a
var reg = /(?:jpg|gif|png|jpeg)$/;reg.test(obj.value)
\u6587\u4ef6\u683c\u5f0f\uff08\u6216\u6587\u4ef6\u7c7b\u578b\uff09\u662f\u6307\u7535\u8111\u4e3a\u4e86\u5b58\u50a8\u4fe1\u606f\u800c\u4f7f\u7528\u7684\u5bf9\u4fe1\u606f\u7684\u7279\u6b8a\u7f16\u7801\u65b9\u5f0f\uff0c\u662f\u7528\u4e8e\u8bc6\u522b\u5185\u90e8\u50a8\u5b58\u7684\u8d44\u6599\u3002\u6bd4\u5982\u6709\u7684\u50a8\u5b58\u56fe\u7247\uff0c\u6709\u7684\u50a8\u5b58\u7a0b\u5e8f\uff0c\u6709\u7684\u50a8\u5b58\u6587\u5b57\u4fe1\u606f\u3002\u6bcf\u4e00\u7c7b\u4fe1\u606f\uff0c\u90fd\u53ef\u4ee5\u4e00\u79cd\u6216\u591a\u79cd\u6587\u4ef6\u683c\u5f0f\u4fdd\u5b58\u5728\u7535\u8111\u5b58\u50a8\u4e2d\u3002
\u6bcf\u4e00\u79cd\u6587\u4ef6\u683c\u5f0f\u901a\u5e38\u4f1a\u6709\u4e00\u79cd\u6216\u591a\u79cd\u6269\u5c55\u540d\u53ef\u4ee5\u7528\u6765\u8bc6\u522b\uff0c\u4f46\u4e5f\u53ef\u80fd\u6ca1\u6709\u6269\u5c55\u540d\u3002\u6269\u5c55\u540d\u53ef\u4ee5\u5e2e\u52a9\u5e94\u7528\u7a0b\u5e8f\u8bc6\u522b\u7684\u6587\u4ef6\u683c\u5f0f\u3002\u5bf9\u4e8e\u786c\u76d8\u673a\u6216\u4efb\u4f55\u7535\u8111\u5b58\u50a8\u6765\u8bf4\uff0c\u6709\u6548\u7684\u4fe1\u606f\u53ea\u67090\u548c1\u4e24\u79cd\u3002\u6240\u4ee5\u7535\u8111\u5fc5\u987b\u8bbe\u8ba1\u6709\u76f8\u5e94\u7684\u65b9\u5f0f\u8fdb\u884c\u4fe1\u606f-\u4f4d\u5143\u7684\u8f6c\u6362\u3002\u5bf9\u4e8e\u4e0d\u540c\u7684\u4fe1\u606f\u6709\u4e0d\u540c\u7684\u5b58\u50a8\u683c\u5f0f\u3002

匹配后缀名。

String.endsWith(".xls");
xls
xlsx
xlsm

1.两点需要注意

1.string.spilt("\\.")分割字符串成子字符串数组,以“.”分割,必须写成string.spilt("\\.")的方式,不能写成string.spilt(".")。斜线必须是反斜线且。

2.获取分割后的字符串数组,要获得最后一个item的index ,方式是int suffixIndex = strArray.length -1;

public String getFileType(String fileName) {
        String[] strArray = fileName.split("\\.");
        int suffixIndex = strArray.length -1;
        System.out.println(strArray[suffixIndex]);
        return "strArray[suffixIndex]";        
    }


/**
 *传入目录,判断是否是xls文件,并返回名字
 */
public static List<String> getFileList(File file) {
    List<String> result = new ArrayList<String>();
    //isDirectory() 测试是否是路径
    if (!file.isDirectory()) {
        System.out.println(file.getAbsolutePath());
        result.add(file.getAbsolutePath());
    } else {
        File[] directoryList = file.listFiles(new FileFilter() {
            public boolean accept(File file) {
            //isFile()  判断file是否是一个文件而不是一个目录
            //.getName().indexOf("txt") 判断文件的名称中带有xls 并且xls不是开头
                if (file.isFile() && file.getName().indexOf("xls") > -1) {
                    return true;
                } else {
                    return false;
                }
            }
        });
        for (int i = 0; i < directoryList.length; i++) {
            result.add(directoryList[i].getPath());
        }
    }
    //返回判断完成的txt后缀的文件路径
    return result;
}


参考代码:
// 读取文件 解析excel
String fileType = filePath.substring(filePath.lastIndexOf(".") + 1,
      filePath.length());
InputStream stream = AliyunOssUtil.downloadObj(filePath);
Workbook wb = null;
if ("xls".equals(fileType)) {
   wb = new HSSFWorkbook(stream);
} else if ("xlsx".equals(fileType)) {
   wb = new XSSFWorkbook(stream);
} else {
   System.out.println("您输入的excel格式不正确");
}


匹配后缀名。
用String.endsWith(".xls");
xls
xlsx
xlsm

如果就没有后缀名的文件判断是不是excel文件,那我也不会。

匹配后缀名。 用String.endsWith(".xls"); xls xlsx xlsm 如果就没有后缀名的文件判断是不是excel文件,那我也不会。

  • java 鎬庢牱鍒ゆ柇涓涓鏂囦欢鏄煶棰戞枃浠,鍋囪鍒汉鎶婇煶棰戞枃浠跺悕瀛楁敼涓簒x.tx...
    绛旓細姣忎釜闊抽鏂囦欢閮芥湁鍏蜂綋鐨勬牸寮锛屾妸鏂囦欢澶磋鍑烘潵灏辫兘鍒ゆ柇鍏舵牸寮忋傚mp3锛屽紑澶存槸11涓猙it銆倃av绛夊叾浠栨枃浠堕兘鏈夊叿浣撶殑鏍煎紡瑙勫畾锛岃鎯宠瘑鍒紝蹇呴』浜嗚В浠栦滑鐨勬牸寮忚鏄庛
  • java鎬庢牱鍒ゆ柇鍥剧墖鏍煎紡
    绛旓細String flname=file.getFileName();int imgType=flname.lastIndexOf(".");String imgTypeStr=flname.substring(imgType);if(!imgTypeStr.equals(".jpg")&&!imgTypeStr.equals(".gif")&&!imgTypeStr.equals(".jpeg")&&!imgTypeStr.equals(".png")&&!imgTypeStr.equals(".swf")){ } ...
  • 鍦JAVA缂栧啓鐨凪P3涓 杩囨护鏂囦欢绫诲瀷 鍒ゆ柇涓篗P3鏍煎紡
    绛旓細File f = new File ("");f.listFiles(new FileFilter(){ public boolean accept(File file) { return file.getName().toLowerCase().endsWith(".mp3");} });鏈濂絫oLowerCase涓涓嬶紝鏈変簺杞欢浠跺緢鎿嶈泲鎶婂悗缂鍚嶆敼鎴愬ぇ鍐欍傘傘
  • java浠g爜濡備綍鑾峰彇鏂囦欢鐨缂栫爜鏍煎紡
    绛旓細鑻ユ兂瀹炵幇鏇村鏉傜殑鏂囦欢缂栫爜妫娴嬶紝鍙互浣跨敤涓涓紑婧愰」鐩甤pdetector锛屽畠鎵鍦ㄧ殑缃戝潃鏄細http://cpdetector.sourceforge.net/銆傚畠鐨勭被搴撳緢灏忥紝鍙湁500K宸﹀彸锛宑pDetector鏄熀浜庣粺璁″鍘熺悊鐨勶紝涓嶄繚璇佸畬鍏ㄦ纭
  • java涓婁紶瑙嗛闄や簡妫鏌ュ悗缂,鎬庝箞鍒ゆ柇鏂囦欢鏍煎紡,鍓8浣嶆潵鍒ゆ柇.flv鏍煎紡鏈夌殑0...
    绛旓細鍒╃敤js灏卞彲浠鍒ゆ柇涓婁紶鏂囦欢鐨鍚庣紑鍚嶏紝鑰屼笖璋锋瓕鐏嫄ie閮藉彲浠ワ紝鍙互鍒ゆ柇澶у皬鍜屽悗缂锛屼粠缃戜笂鎵炬壘锛屾壘涓嶅埌鎴戠粰浣
  • java鎬庝箞鑾峰彇鏂囦欢缂栫爜鏍煎紡?
    绛旓細娌¢敊锛屽氨杩欐牱鍋氾紝鏂囦欢鏍煎紡鍜屾枃浠跺唴瀹癸紝涓嶆槸杩欐牱鐨勩傛櫘閫氭枃浠讹紝寮濮嬪氨鏄枃浠跺唴瀹逛簡銆傛湁缂栫爜鐨勶紝寮澶村厛鏄紪鐮佺殑瀹氫箟锛屾濡鍒ゆ柇璇彞鎵鍐欑殑閭f牱
  • JAVA绋嬪簭缂栧啓鐨鏂囦欢鏄粈涔鏍煎紡鐨
    绛旓細JAVA 绋嬪簭缂栧啓鐨勬簮鏂囦欢锛婧愪唬鐮锛夋槸浠".java"涓虹粨灏剧殑锛孞VM锛圝AVA铏氭嫙鏈鸿В鏋愮殑鏂囦欢锛夋槸浠".class"涓虹粨灏剧殑锛".class"鏂囦欢灏辨槸java鐨鍙墽琛屾枃浠讹紝鍚.exe鏂囦欢鍏锋湁鍚岀瓑鐨勬晥鏋滐紝.class鏂囦欢閲囩敤鐨勬槸榄斿姏鏁板瓧瀛樺偍锛屽悓鏃朵负浜嗗湪涓嶅悓鐨凜PU涓嬭繍琛岋紝瑙勫畾浜嗗瓧鑺傜殑淇濆瓨褰㈠紡锛岄噰鐢ㄥぇ绔瓧鑺傞『搴(BIG_ENDIAN)鏉ヤ繚瀛樼殑...
  • JAVA绋嬪簭缂栧啓鐨鏂囦欢鏄粈涔鏍煎紡鐨
    绛旓細JAVA 绋嬪簭缂栧啓鐨勬簮鏂囦欢锛婧愪唬鐮锛夋槸浠".java"涓虹粨灏剧殑锛孞VM锛圝AVA铏氭嫙鏈鸿В鏋愮殑鏂囦欢锛夋槸浠".class"涓虹粨灏剧殑锛".class"鏂囦欢灏辨槸java鐨鍙墽琛屾枃浠讹紝鍚.exe鏂囦欢鍏锋湁鍚岀瓑鐨勬晥鏋滐紝.class鏂囦欢閲囩敤鐨勬槸榄斿姏鏁板瓧瀛樺偍锛屽悓鏃朵负浜嗗湪涓嶅悓鐨凜PU涓嬭繍琛岋紝瑙勫畾浜嗗瓧鑺傜殑淇濆瓨褰㈠紡锛岄噰鐢ㄥぇ绔瓧鑺傞『搴(BIG_ENDIAN)鏉ヤ繚瀛樼殑...
  • 缂栧啓java浠g爜鏉ュ疄鐜版瘡绉鏂囦欢鐨鏂囦欢澶撮暱鍟ユ牱
    绛旓細鐪熷績娌$湅鏄庣櫧锛屾槸鎸囩敤java浠g爜璇绘枃浠跺ご锛熸瘡绉鏂囦欢鐨鏂囦欢澶存槸涓嶄竴鏍风殑锛岃濡傛枃鏈枃浠朵竴鑸病鏂囦欢澶达紝鑰岃薄doc鏂囦欢銆亁ls鏂囦欢銆乪xe鏂囦欢銆乨ll鏂囦欢绛夐兘鏈夎嚜宸辩殑鏂囦欢鏍煎紡锛屼篃灏辨湁鑷繁鐨勬枃浠跺ご銆俲ava璇绘枃浠舵湁2绉嶆柟寮忥紝涓绉嶅彨杈撳叆娴侊紝鍙︿竴绉嶅氨鏄殢鏈鸿闂紝浣犺繖涓敤娴佸氨鍙互浜嗐侷nputStream in = new ...
  • java 璇诲彇鏂囦欢鍚,鎬庢牱鍒ゆ柇瀹冪殑鐪熸鐨勬墿灞曞悕
    绛旓細闄ら潪瑕佺敤浠g爜鍒嗘瀽鏂囦欢鏍煎紡锛屽惁鍒欎笉澶彲鑳姐備絾鏄亣璁句綘鍙槸澶勭悊灏戞暟鍑犱釜鐗瑰畾绫诲瀷鐨勬枃浠讹紝姣斿doc, xls绛夌殑锛屽彲浠ョ敤涓浜涗笓鐢ㄧ殑java宸ュ叿姣斿POI鐨勮鍙栦竴涓嬶紝鐪嬫姏鍑哄紓甯镐笉锛屾病鏈夌殑灏卞彲浠ユ柇瀹氫负璇ョ被鍨嬩簡銆
  • 扩展阅读:javascript高级视频 ... javac exe指 ... java代码视频 ... java必背代码大全 ... javascript入门 ... java代码网站 ... java cmd ... java简单好玩的代码 ... 一个简单的java代码 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网