我在MainActivity.java中有以下代码行:

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


它将引发以下错误:java.io.FileNotFoundException

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

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'
}

最佳答案

看来您正在使用"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);

07-28 01:46
查看更多