本文实例讲述了Android开发实现读取assets目录下db文件的方法。分享给大家供大家参考,具体如下:
最近准备打算写一个关于天气预报的app,偶然的机会在一大神的博客上看到了一个获取天气的api,获取天气是通过城市的cityID,项目中准备通过读取weather_city.db数据库来查询cityID,这篇文章写怎么读取assets目录下的db文件,其实方法也挺简单的就是把assets目录下的db文件复制一份到”/data/data/” + packName + “/”目录下而已。
public class DBManager { private String DB_NAME = "weather_city.db"; private Context mContext; public DBManager(Context mContext) { this.mContext = mContext; } //把assets目录下的db文件复制到dbpath下 public SQLiteDatabase DBManager(String packName) { String dbPath = "/data/data/" + packName + "/databases/" + DB_NAME; if (!new File(dbPath).exists()) { try { FileOutputStream out = new FileOutputStream(dbPath); InputStream in = mContext.getAssets().open("weather_city.db"); byte[] buffer = new byte[1024]; int readBytes = 0; while ((readBytes = in.read(buffer)) != -1) out.write(buffer, 0, readBytes); in.close(); out.close(); } catch (IOException e) { e.printStackTrace(); } } return SQLiteDatabase.openOrCreateDatabase(dbPath, null); } //查询 public City query(SQLiteDatabase sqliteDB, String[] columns, String selection, String[] selectionArgs) { City city = null; try { String table = "city"; Cursor cursor = sqliteDB.query(table, columns, selection, selectionArgs, null, null, null); if (cursor.moveToFirst()) { String parentCity = cursor.getString(cursor .getColumnIndex("parent")); String phoneCode = cursor.getString(cursor.getColumnIndex("phone_code")); String name = cursor.getString(cursor.getColumnIndex("name")); String pinyin = cursor.getString(cursor.getColumnIndex("pinyin")); String cityID = cursor.getString(cursor.getColumnIndex("posID")); String areaCode = cursor.getString(cursor.getColumnIndex("area_code")); city = new City(parentCity, name, pinyin, phoneCode, cityID, areaCode); cursor.moveToNext(); cursor.close(); } } catch (Exception e) { e.printStackTrace(); } return city; } }
为了方便数据的使用,我们建一个City类,对应City表中的字段,如下:
public class City { private String parentCity; private String childCity; private String pinyin; private String phoneCode; private String cityID; private String areaCode; public City(String parentCity, String childCity, String pinyin, String phoneCode, String cityID, String areaCode) { this.parentCity = parentCity; this.childCity = childCity; this.pinyin = pinyin; this.phoneCode = phoneCode; this.cityID = cityID; this.areaCode = areaCode; } public String getParentCity() { return parentCity; } public void setParentCity(String parentCity) { this.parentCity = parentCity; } public String getAreaCode() { return areaCode; } public void setAreaCode(String areaCode) { this.areaCode = areaCode; } public String getCityID() { return cityID; } public void setCityID(String cityID) { this.cityID = cityID; } public String getPhoneCode() { return phoneCode; } public void setPhoneCode(String phoneCode) { this.phoneCode = phoneCode; } public String getPinyin() { return pinyin; } public void setPinyin(String pinyin) { this.pinyin = pinyin; } public String getChildCity() { return childCity; } public void setChildCity(String childCity) { this.childCity = childCity; } }
测试代码:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); contentTextView = (TextView) findViewById(R.id.content); dbManager = new DBManager(this); sqLiteDatabase = dbManager.initDBManager(getPackageName()); String[] columns = new String[]{"parent", "name", "posID", "pinyin", "phone_code", "area_code"}; String selection = "parent=?" + "AND" + " name=?"; String[] selectionArgs = new String[]{"北京", "丰台"}; City city = dbManager.query(sqLiteDatabase, columns, selection, selectionArgs); contentTextView.setText("邮编:" + city.getAreaCode() + "拼音:" + city.getPinyin() + "电话区号" + city.getPhoneCode() + "cityID:" + city.getCityID()); }
读取的数据与表中的数据一致
更多关于Android相关内容感兴趣的读者可查看本站专题:《Android文件操作技巧汇总》、《Android操作SQLite数据库技巧总结》、《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android布局layout技巧总结》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》及《Android控件用法总结》
希望本文所述对大家Android程序设计有所帮助。
本文向大家介绍Android开发实现读取Assets下文件及文件写入存储卡的方法,包括了Android开发实现读取Assets下文件及文件写入存储卡的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android开发实现读取Assets下文件及文件写入存储卡的方法。分享给大家供大家参考,具体如下: 调用一个反编译的.so文件,查看起加密和解密情况,需要解析上万的数组,而so文件加密解密
本文向大家介绍Android Studio下添加assets目录的实现方法,包括了Android Studio下添加assets目录的实现方法的使用技巧和注意事项,需要的朋友参考一下 有时候需要放置一些文件而且不被proguard压缩,可以放到assets目录中。 但是工程默认并未创建assets目录,那么如何在android studio中创建assets目录呢? 目录位置为:XXX\src\m
本文向大家介绍java读取resource目录下文件的方法示例,包括了java读取resource目录下文件的方法示例的使用技巧和注意事项,需要的朋友参考一下 本文主要介绍的是java读取resource目录下文件的方法,比如这是你的src目录的结构 我们希望在Test.java中读取test.txt文件中的内容,那么我们可以借助Guava库的Resource类 示例代码如下 核心函数就是Reso
本文向大家介绍python读取目录下最新的文件夹方法,包括了python读取目录下最新的文件夹方法的使用技巧和注意事项,需要的朋友参考一下 如下所示: 以上这篇python读取目录下最新的文件夹方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍android文件操作——读取assets和raw文件下的内容,包括了android文件操作——读取assets和raw文件下的内容的使用技巧和注意事项,需要的朋友参考一下 来自Resources和Assets 中的文件只可以读取而不能进行写的操作。 assets文件夹里面的文件都是保持原始的文件格式,需要用AssetManager以字节流的形式读取文件。 1. 先在Activity
本文向大家介绍php读取目录及子目录下所有文件名的方法,包括了php读取目录及子目录下所有文件名的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php读取目录及子目录下所有文件名的方法,分享给大家供大家参考。具体实现方法如下: 一般来说php中读取目录下的文件名的方式确实不少,最简单的是scandir,具体代码如下: 稍微复杂点的,来自于php手册: 这些都只能读取当前指定目录下的文