Check file extension in Java
Solution 1
following
extension != excel
should be
!excel.equals(extension)
or
!excel.equalsIgnoreCase(extension)
See also
Solution 2
==
tests referentially equality. For value equality test, use .equals
. Use String#equalsIgnoreCase
if you want the case to be disregarded during the equality test.
Another thing: Don't reinvent the wheel, unless it's badly broken. In your case, you should be using Apache Commons' FilenameUtils#isExtension to check the extension.
Solution 3
if (extension != excel){
JOptionPane.showMessageDialog(null, "Choose an excel file!");
}
should be used as
if (!extension.equals(excel)){
JOptionPane.showMessageDialog(null, "Choose an excel file!");
}
And
if (upload == "OK") {
JOptionPane.showMessageDialog(null,"Upload Successful!");
}
as
if ("OK".equals(upload)) {
JOptionPane.showMessageDialog(null,"Upload Successful!");
}
Solution 4
use
excel.equals(extension)
or
excel.equalsIgnoreCase(extension)
Solution 5
You can use Apache Commons Api to check the file extension
String filename = file.getName();
if(!FilenameUtils.isExtension(filename,"xls")){
JOptionPane.showMessageDialog(null, "Choose an excel file!");
}
http://commons.apache.org/io/api-release/index.html?org/apache/commons/io/package-summary.html
Joe88
Updated on January 20, 2020Comments
-
Joe88 over 4 years
I have to import data from an Excel file to database and to do this, I would like to check the extension of the chosen file.
This is my code:
String filename = file.getName(); String extension = filename.substring(filename.lastIndexOf(".") + 1, filename.length()); String excel = "xls"; if (extension != excel) { JOptionPane.showMessageDialog(null, "Choose an excel file!"); } else { String filepath = file.getAbsolutePath(); JOptionPane.showMessageDialog(null, filepath); String upload = UploadPoData.initialize(null, filepath); if (upload == "OK") { JOptionPane.showMessageDialog(null, "Upload Successful!"); } }
But I always get:
Choose an excel file!
I can't find what is wrong with my code, could someone please help.