Android实现Excel数据导入SQLlite,并用ListView展示。并且实现模糊查询

Android实现Excel数据导入SQLlite,并用ListView展示。实现模糊查询前言今天朋友提出一个需求,有一个Excel表格,需要实现把每项数据展示出来,并且可以用某一项来进行查询筛选。首先我们应该思考如何把Excel上的数据存入数据库?我的思路是直接用工具转成数据库文件,复制到项目里面去,然后再查出来展示,这个时候就可以用查询语句来控制我们需要的数据了。一、怎么把Excel转成数据库文件?把Excel另存为.scv文件然后用记事本打开,另存时选择编码为UTF-8下载 SQLit
摘要由CSDN通过智能技术生成

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))
  • 3
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值