尝试在Android中打开Excel文件时,不断收到FileNotFound异常

时间:2019-01-24 19:38:07

标签: java android android-studio apache-poi

MainActivity.java中有以下代码行:

Workbook myWorkBook = WorkbookFactory.create(new File("C://sampleWB.xlsx"));

会引发以下错误:java.io.FileNotFoundException

我也尝试过将excel文件添加到资产文件夹(应用程序> src>主>资产),并尝试了以下代码,但是抛出了相同的异常。

Workbook myWorkBook = WorkbookFactory.create(new File("sampleWB.xlsx"));

我在AndroidManifest.xml中添加了以下内容,但它也无法解决任何问题:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

如果有帮助,这是我的build.gradle文件:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.test.testProj"
        minSdkVersion 26
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0-alpha1'
    implementation 'com.android.support.constraint:constraint-layout:1.1.2'
    implementation "org.apache.poi:poi:3.17"
    implementation "org.apache.poi:poi-ooxml:3.17"
    implementation 'com.fasterxml:aalto-xml:1.0.0'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

2 个答案:

答案 0 :(得分:2)

似乎您使用"C://sampleWB.xlsx"作为文件名。如this answer中所述,:/对于文件名不是有效字符。

要访问assets文件夹中的文件,请参考this answer

  

将您的文本文件放在Android项目下的/ assets目录中,并按如下所示使用AssetManager类进行访问。

AssetManager am = context.getAssets();
InputStream is = am.open("default_book.txt");
  

或者,您也可以将文件放在/ res / raw目录中,可以通过该目录通过id如下访问文件

InputStream is = 
context.getResources().openRawResource(R.raw.default_book);

答案 1 :(得分:1)

首先,您需要使用

请求存储读取权限以在运行时读取文件
ActivityCompat.requestPermissions(thisActivity,
            new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},
            READ_PERMISSION_REQUEST_CODE);

您可以参考此以获取更多信息- https://developer.android.com/training/permissions/requesting

然后,如果要访问资产文件夹中的文件-

AssetManager assetManager = getAssets();
assetManager.open("fileName");