我正在用netbeans开发一个android应用程序。我正在尝试使用opencsv读取CSV文件。当我将文件放在resources文件夹中并尝试从那里读取它时,在构建时出现了一个错误,说明资源目录无效。我应该在哪里存储csv文件,以便每次应用程序启动时都可以读取它?
发布于 2013-11-14 18:13:54
您应该将csv文件放在assets文件夹中。
InputStreamReader is = new InputStreamReader(getAssets()
.open("filename.csv"));
BufferedReader reader = new BufferedReader(is);
reader.readLine();
String line;
while ((line = reader.readLine()) != null) {
}
发布于 2016-12-24 13:02:51
作为另一种选择,可以看看uniVocityParsers。它提供了大量解析分隔文件的方法。下面的示例将Csv文件(见下图)从res/raw文件夹加载到InputStream对象中,并以列的方式读取它( key=Column &value=ColumnValues所在的地图)。
//Gets your csv file from res/raw dir and load into a InputStream.
InputStream csvInputStream = getResources().openRawResource(R.raw.calendario_bolsa);
//Instantiate a new ColumnProcessor
ColumnProcessor columnProcessor = new ColumnProcessor();
//Define a class that hold the file configuration
CsvParserSettings parserSettings = new CsvParserSettings();
parserSettings.getFormat().setLineSeparator("\n");
parserSettings.setHeaderExtractionEnabled(true);
parserSettings.setProcessor(columnProcessor);
//Creates a new CsvParser, passing the settings into its construtor:
CsvParser csvParser = new CsvParser(parserSettings);
//Calls parse method, instantiating an InputStreamReader, passing to its constructor the InputStream object
csvParser.parse(new InputStreamReader(csvInputStream));
//Gets the csv data as a Map of Column / column values.
Map<String, List<String>> columnarCsv = columnProcessor.getColumnValuesAsMapOfNames();
要将univocityParsers添加到你的安卓项目中:
compile group: 'com.univocity', name: 'univocity-parsers', version: '2.3.0'
发布于 2016-11-03 04:05:30
使用opencsv:
InputStream is = context.getAssets().open(path);
InputStreamReader reader = new InputStreamReader(is, Charset.forName("UTF-8"));
List<String[]> csv = new CSVReader(reader).readAll();
https://stackoverflow.com/questions/19974708
复制相似问题