我有一个包含大量内容的列表视图,我想知道如何将列表视图中的内容保存为文本文件?我从数据库中提取所有内容。
答案 0 :(得分:2)
尝试数组序列化(您可以序列化并返回对象)
ObjectOutputStream out;
Object[] objs = new Object[yourListView.getCount()];
for (int i = 0 ; i < youeListView.getCount();i++) {
Object obj = (Object)yourListView.getItemAtPosition(i);
objs[i] = obj;
}
try {
out = new ObjectOutputStream(
new FileOutputStream(
new File(yourFile.txt)));
out.writeObject(objs);
out.flush();
out.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
答案 1 :(得分:1)
我想要保存用户点击的行的内容:
如果使用ListActivity覆盖onListItemClick(ListView lv,View v,int position,long id)。然后String str = lv.getItemAtPosition(position).toString()可以给你包含在行中的字符串。根据您的具体实施,存在其他可能性。您还可以访问被点击的视图。
我认为您不想保存所有行的内容,因为您已经拥有了数据库中的内容,并且可以从那里进行查询和保存。
一旦你有了字符串。创建一个新文件并写入它。
写入档案的一种方式:
try {
File f = File.createTempFile("file", ".txt", Environment.getExternalStorageDirectory ());
FileWriter fw = new FileWriter(f);
fw.write(str);
fw.close();
} catch (IOException e) {
e.printStackTrace();
Toast.makeText(getApplicationContext(), "Error while saving file", Toast.LENGTH_LONG).show();
}
答案 2 :(得分:0)
写入文件的机制已经很好了,但我想补充一点:
我从数据库中提取所有内容
在这种情况下,您可以从ListView获取光标,然后使用SQLiteCursor.getItemAtPosition()
。
private String getCsvFromViewCursor(ListView myListView) {
StringBuilder builder = new StringBuilder();
SQLiteCursor cursor;
builder.append("\"Field 1\",\"Field 2\"\n");
for (int i = 0; i < myListView.getCount(); i++ ){
cursor = (SQLiteCursor) myListView.getItemAtPosition(i);
builder.append("\"").append(cursor.getString(0)).append("\",");
builder.append("\"").append(cursor.getString(1)).append("\"\n");
}
return builder.toString();
}