Написание проблемы в каталоге загрузки - PullRequest
3 голосов
/ 12 марта 2020

Я пытаюсь записать этот xlsx файл в каталог загрузки Samsung Galaxy Tab A 2019 (Android 9.0). Если я пытаюсь сделать это на моем эмуляторе (Google Pixel C с android 9.0), он работает без проблем, и я вижу файл. Если я передаю приложение моему клиенту, оно выдает ошибку, которая отслеживается этой функцией:

try {
     importIntoExcel();
     DynamicToast.makeSuccess(UserList.this, "Saved!", 2000).show();
     b1.setEnabled(true);
} catch (IOException e) {
     DynamicToast.makeError(UserList.this, "Error!", 2000).show();
     e.printStackTrace();
}

К сожалению, я не вижу трассировки стека, так как не могу подключить планшет клиента к моему P C. Этот метод не работает:

private void importIntoExcel() throws IOException {
    String[] columns = {"Numero Test", "Codice ID", "Genere", "Data di nascita", "Protocollo", "Data del test", " ", "Cornice", "Nome cornice", "Fluidità", "Flessibilità",
            "Originalita'", "Elaborazione'", "Titolo", "Tempo Reazione", "Tempo Completamento", "Numero cancellature", "Numero Undo"};


    Workbook workbook = new XSSFWorkbook();
    Sheet sheet = workbook.createSheet("RiepilogoTest");

    Font headerFont = workbook.createFont();
    headerFont.setBold(true);
    headerFont.setFontHeightInPoints((short) 14);
    headerFont.setColor(IndexedColors.RED.getIndex());

    CellStyle headerCellStyle = workbook.createCellStyle();
    headerCellStyle.setFont(headerFont);
    headerCellStyle.setAlignment(HorizontalAlignment.CENTER_SELECTION);

    // Create a Row
    Row headerRow = sheet.createRow(0);

    for (int i = 0; i < columns.length; i++) {
        Cell cell = headerRow.createCell(i);
        cell.setCellValue(columns[i]);
        cell.setCellStyle(headerCellStyle);

    }

    // Create Other rows and cells with contacts data
    int rowNum = 1;

    //Inserting the data
    File dir = new File("/data/user/0/com.example.williamstest/");

    for (File file : dir.listFiles()) {
        if (file.getName().startsWith("app_draw")) {
            String typeTest = file.getName().replaceAll("[^\\d.]", "");
            if (new File(file.getAbsolutePath() + "/infotest.txt").exists()) {
                FileReader f = new FileReader(file.getAbsolutePath() + "/infotest.txt");
                LineNumberReader reader = new LineNumberReader(f);
                String line;
                String protocollo = "";
                line = reader.readLine();
                Row row = null;
                if (line.equals(userLogged)) {
                    row = sheet.createRow(rowNum++);
                    row.createCell(0).setCellValue("Test: " + typeTest);
                    line = reader.readLine();
                    row.createCell(2).setCellValue(line);
                    line = reader.readLine();
                    if (line.equals("0")) row.createCell(2).setCellValue("/");
                    row.createCell(3).setCellValue(line);
                    line = reader.readLine();
                    protocollo = line;
                    row.createCell(4).setCellValue(line);
                    line = reader.readLine();
                    row.createCell(5).setCellValue(line);
                    line = reader.readLine();
                    row.createCell(1).setCellValue(line);
                }
                for (int i=0; i<12; i++) {
                    String content = "";
                    reader = new LineNumberReader(new FileReader(file.getAbsolutePath() + "/" + protocollo + (i + 1) + "_score.txt"));
                    while ((line = reader.readLine()) != null) {
                        content+=line+"\n";
                    }

                    String[] values = content.split("\n");
                    row.createCell(6).setCellValue(" "); //Vuota
                    row.createCell(7).setCellValue(i+1); //Cornice
                    row.createCell(8).setCellValue(values[4]); //Nome cornice
                    row.createCell(9).setCellValue(values[0]); //Fluidita
                    row.createCell(10).setCellValue(values[1]); //Flessibilita
                    row.createCell(11).setCellValue(values[2]); //Originalita'
                    row.createCell(12).setCellValue(values[3]); //Elaborazione
                    row.createCell(13).setCellValue(values[9]); //Titolo
                    row.createCell(14).setCellValue(values[5]); //Tempo reazione
                    row.createCell(15).setCellValue(values[6]); //Tempo Completamento
                    row.createCell(16).setCellValue(values[7]); //Numero cancellature
                    row.createCell(17).setCellValue(values[8]); //Numero undo

                    row = sheet.createRow(rowNum++);
                    row.createCell(0).setCellValue(" ");
                    row.createCell(1).setCellValue(" ");
                    row.createCell(2).setCellValue(" ");
                    row.createCell(3).setCellValue(" ");
                    row.createCell(4).setCellValue(" ");
                    row.createCell(5).setCellValue(" ");
                }
                f.close();
            }
        }
    }

    sheet.setDefaultColumnWidth(23);

    // Write the output to a file
    if (new File(Environment.getExternalStorageDirectory(), "Download/risultatiTest.xlsx").exists())
        new File(Environment.getExternalStorageDirectory(), "Download/risultatiTest.xlsx").delete();
    FileOutputStream fileOut = new FileOutputStream(new File(Environment.getExternalStorageDirectory(), "Download/risultatiTest.xlsx"));
    workbook.write(fileOut);
    fileOut.close();
}

Я также написал этот метод, который сохраняет в том же каталоге, и он работает, поэтому я не думаю, что это проблема с разрешениями:

private void generateImages() throws IOException {
    File dir = new File("/data/user/0/com.example.williamstest/");
    File mediaStorageDir = new File(Environment.getExternalStorageDirectory(), "/Download/ImmaginiTest");
    if (!mediaStorageDir.exists()) {
        if (!mediaStorageDir.mkdirs())
            Log.d("App", "failed to create directory");
    } else {
            if (mediaStorageDir.isDirectory()) {
                for (File child : mediaStorageDir.listFiles())
                    deleteRecursive(child);
            }
            mediaStorageDir.delete();
            mediaStorageDir.mkdirs();
        }
    for (File file : dir.listFiles()) {
        if (file.getName().startsWith("app_draw") && Character.isDigit(file.getName().charAt(file.getName().length() - 1))) {
            File makingDir = new File(Environment.getExternalStorageDirectory(), "/Download/ImmaginiTest/Test"+file.getName().substring(file.getName().length() - 1));
            makingDir.mkdirs();
            for (File fileS : file.listFiles()) {
                if (fileS.getName().endsWith(".png")) {
                    Bitmap b = BitmapFactory.decodeStream(new FileInputStream(fileS));
                    File mypath=new File(makingDir, fileS.getName());
                    FileOutputStream fos = null;
                    try {
                        fos = new FileOutputStream(mypath);
                        b.compress(Bitmap.CompressFormat.PNG, 100, fos);
                    } catch (Exception e) {
                        e.printStackTrace();
                    } finally {
                        try {
                            fos.close();
                        } catch (IOException e) {
                            e.printStackTrace();
                        }
                    }
                }
            }
        }
    }
}

Ответы [ 4 ]

3 голосов
/ 17 марта 2020

У вас есть какой-нибудь logcat, который можно использовать, чтобы сузить источник ошибки?

Также вы могли бы начать с использования такой строки c magi:

  • File dir = new File("/data/user/0/com.example.williamstest/");
  • File makingDir = new File(Environment.getExternalStorageDirectory(), "/Download/ImmaginiTest/Test"+file.getName().substring(file.getName().length() - 1));

По состоянию на API 29 Environment.getExternalStoragePublicDirectory() устарело. Взгляните на этот AndroidStudio getExternalStoragePublicDirectory в API 29 .

1 голос
/ 19 марта 2020

Традиционно внешним хранилищем обычно является SD-карта, но оно также может быть реализовано как встроенное хранилище.

Таким образом, необходимо проверить, есть ли у вас один и , если он монтируется перед доступом к файлу в Environment.getExternalStorageDirectory(). В противном случае вам нужен внутренний каталог как запасной вариант. Проверьте do c здесь , чтобы узнать, как это сделать.

Кроме того, если вы нацелены на уровень API 29, убедитесь, что вы используете android:requestLegacyExternalStorage="true" в теге application манифеста тоже , Проверьте это здесь .

0 голосов
/ 21 марта 2020

Возможно, файлы для записи на компьютерах и android устройствах различаются. Новые версии android блокируют доступ приложений к некоторым папкам. Поэтому попробуйте другую папку, чтобы записать ее. Возможно, не создавайте новую папку и не пишите ее в существующую.

Также, как другие говорят, Environment.getExternalStorageDirectory() устарела, и вы не должны использовать ее в более новой версии android, но старые вы все еще могли.

Также вы не можете на 100% доверять эмуляторам, потому что это не на 100% то же самое

0 голосов
/ 20 марта 2020

На некоторых устройствах и в более новых Android версиях Environment.getExternalStorageDirectory() больше не возвращает действительный путь. Попробуйте использовать Context.getExternalFilesDir(null) вместо этого, он должен вернуть этот путь: /storage/emulated/0/Android/data/your.package.name/. Попробуйте, чтобы увидеть, если это проблема. Вот do c.

Я рекомендую вам эмулировать некоторые подобные устройства Samsung и посмотреть, сможете ли вы повторить ошибку, чтобы взглянуть на вывод logcat

...