Продолжайте получать FileNotFound Exception при попытке открыть файл Excel в Android - PullRequest
0 голосов
/ 24 января 2019

У меня есть следующая строка кода в MainActivity.java:

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

, которая выдает следующую ошибку: java.io.FileNotFoundException

Я также попытался добавить файл excel в папку активов (app> src> main> assets) и попробовал следующий код, но выдается то же исключение.

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 голосов
/ 24 января 2019

Кажется, вы используете "C://sampleWB.xlsx" в качестве имени файла. Как описано в , этот ответ : и / не являются допустимыми символами для имени файла.

Чтобы получить доступ к файлам в папке assets, обратитесь к этому ответу :

Поместите текстовый файл в каталог / assets в проекте Android и используйте для доступа к нему класс AssetManager следующим образом.

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

Или вы также можете поместить файл в каталог / res / raw, откуда к файлу можно получить доступ по идентификатору, как показано ниже

InputStream is = 
context.getResources().openRawResource(R.raw.default_book);
0 голосов
/ 24 января 2019

Во-первых, вам нужно запросить разрешение на чтение для чтения файла во время выполнения, используя

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");
...