我做了这个方法,它读取一个csv文件,并将数据存储到包含在地图中的ArrayList。Map..This方法在java中单独运行。但是当我在android中实现它时,它didn工作和应用程序崩溃..我一直试图解决它所以任何帮助非常感谢谢谢..以下是我尝试在Android中使用此方法通过读取SD卡中的csv文件。当我使用get方法时,它似乎崩溃了。在下面你可以看到logcat。阅读文件Android
public class New extends Activity {
private static Map<String, List<String>> values;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
try {
FileReader fr = new FileReader(Environment.getExternalStorageDirectory() + "/" + "Android/data/"
+ getPackageName().toString()+ "/" + "SOPARC.csv");
values = parseCsv(fr, ",", true);
} catch (IOException e) {
e.printStackTrace();
}
values.get("Date").get(2);
}
public static Map<String, List<String>> parseCsv(Reader reader, String separator, boolean hasHeader) throws IOException {
Map<String, List<String>> values = new LinkedHashMap<String, List<String>>();
List<String> columnNames = new LinkedList<String>();
BufferedReader br = null;
br = new BufferedReader(reader);
String line;
int numLines = 0;
while ((line = br.readLine()) != null) {
if (StringUtils.isNotBlank(line)) {
if (!line.startsWith("#")) {
String[] tokens = line.split(separator);
if (tokens != null) {
for (int i = 0; i < tokens.length; ++i) {
if (numLines == 0) {
columnNames.add(hasHeader ? tokens[i] : ("row_"+i));
} else {
List<String> column = values.get(columnNames.get(i));
if (column == null) {
column = new LinkedList<String>();
}
column.add(tokens[i]);
values.put(columnNames.get(i), column);
}
}
}
++numLines;
}
}
}
return values;
}
后堆栈跟踪误差..或试试这个: http://code.google.com/p/secrets-for-android/source/browse/trunk/src/au/com/bytecode/ opencsv/CSVReader.java – Davide 2014-08-29 19:31:16
这是否有帮助? – user3156801 2014-08-29 19:58:12
看起来不相关。 – auselen 2014-08-29 20:06:40