Android CSV文件选择存储并获取其路径

时间:2016-03-04 05:50:27

标签: android csv

我想从外部存储导入csv然后更新我的数据库但是当我从下载的文件夹FileNotFoundExpception中选择csv时。这是异常System.err:java.io.FileNotFoundException:/document/primary:Download/GuestCSV.csv:open failed:ENOENT(没有这样的文件或目录)  这是我的代码。请仔细检查我的代码并帮助我找到解决方案。

            Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
            intent.addCategory(Intent.CATEGORY_OPENABLE);
            intent.setType("text/*");
            startActivityForResult(Intent.createChooser(intent, "Open CSV"), ACTIVITY_CHOOSE_FILE);


@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    switch (requestCode) {
        case ACTIVITY_CHOOSE_FILE: {
            if (resultCode == RESULT_OK) {
                onImport(new File(data.getData().getPath()));
            }
        }
    }
}

public void onImport(File files) {
    try {
        CSVReader reader = new CSVReader(new FileReader(files));
        String[] nextLine;
        try {
            while ((nextLine = reader.readNext()) != null) {

                // nextLine[] is an array of values from the line
                String emailID = nextLine[0];
                String guestName = nextLine[1];
                String guestSource = nextLine[2];
                String guestPhone = nextLine[3];
                String guestCount = nextLine[4];
                String guestCreatedDate = nextLine[5];
                String guestModifiedDate = nextLine[6];
                GuestDetails guestDetails = new GuestDetails();
                guestDetails.setEmail(emailID);
                guestDetails.setUsername(guestName);
                guestDetails.setPhone(guestPhone);
                guestDetails.setSource(guestSource);
                guestDetails.setCount(Integer.valueOf(guestCount));
                guestDetails.setCreatedDate(guestCreatedDate);
                guestDetails.setModifiedDate(guestModifiedDate);
                try {
                    helper.insertGuest(guestDetails);
                } catch (SQLiteConstraintException e) {
                    e.printStackTrace();
                }
                Toast.makeText(getApplicationContext(), "Data inserted into table...", Toast.LENGTH_SHORT).show();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }

    } catch (FileNotFoundException e) {
        e.printStackTrace();
    }
}

1 个答案:

答案 0 :(得分:0)

我希望此代码能为您提供帮助!!

Intent i = new Intent(Intent.ACTION_GET_CONTENT);
Uri uri = Uri.parse(Environment.getExternalStorageDirectory().getPath()+ "/YourFolder/");
intent.setDataAndType(uri, "text/csv");
startActivity(Intent.createChooser(i, "Open folder"));