Android实现Excel数据导入SQLlite,并用ListView展示。实现模糊查询
前言
今天朋友提出一个需求,有一个Excel表格,需要实现把每项数据展示出来,并且可以用某一项来进行查询筛选。首先我们应该思考如何把Excel上的数据存入数据库?我的思路是直接用工具转成数据库文件,复制到项目里面去,然后再查出来展示,这个时候就可以用查询语句来控制我们需要的数据了。
一、怎么把Excel转成数据库文件?
1、把Excel另存为.csv文件
2、然后用记事本打开,另存时选择编码为UTF-8
3、下载 SQLite Expert Professional 4 数据库管理工具
点击直接下载
4、新建数据库
5、选中数据库,右键选择 Import Text File
6、数据库文件在这里,直接复制到Android项目的assets目录下
7、补充 没有Assets文件夹,在Android studio中选中project结构下创建
二、代码实现
1、数据库文件
在android开发时,很多时候我们会使用可视化界面创建数据库,或者拿到别人的数据库使用,这时就需要我们将db文件手动加入到assets文件是夹中并读取。但是当我们把应用的apk部署到真机上的时候,已经创建好的数据库及其里边的数据是不能随着apk一起安装到真机上的。
解决方法很简单,只需要把assets目录下的db文件复制一份到SDCard中的”/data/data/” + packName + “/”目录下就可以了。
原文链接:https://blog.csdn.net/x15037308498/article/details/79458655
代码如下(示例):
public class SQLdm {
//数据库存储路径
//com.example.myapplication是你的包名
//test.dbtest.db是你的数据库文件名称,一定要改成你自己的
String filePath = "data/data/com.example.myapplication/test.db";
//数据库存放的文件夹 data/data/com.example.myapplication 下面
String pathStr = "data/data/com.example.myapplication";
SQLiteDatabase database;
public SQLiteDatabase openDatabase(Context context){
System.out.println("filePath:"+filePath);
File jhPath=new File(filePath);
//查看数据库文件是否存在
if(jhPath.exists()){
Log.i("test", "存在数据库");
//存在则直接返回打开的数据库
return SQLiteDatabase.openOrCreateDatabase(jhPath, null);
}else{
//不存在先创建文件夹
File path=new File(pathStr);
Log.i("test", "pathStr="+path);
if (path.mkdir()){
Log.i("test", "创建成功");
}else{
Log.i("test", "创建失败");
};
try {
//得到资源
AssetManager am= context.getAssets();
//得到数据库的输入流
InputStream is=am.open("test.db");
Log.i("test", is+"");
//用输出流写到SDcard上面
FileOutputStream fos=new FileOutputStream(jhPath);
Log.i("test", "fos="+fos);
Log.i("test", "jhPath="+jhPath);
//创建byte数组 用于1KB写一次
byte[] buffer=new byte[1024];
int count = 0;
while((count = is.read(buffer)