在 Eclipse 里新建好工程后,默认会有一个 assets
目录,在 Eclipse 中直接将准备好的 sqlite 数据库复制到该目录中,然后在主 Activity 里面编码:
package com.test.db; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.io.OutputStream; import java.io.UnsupportedEncodingException; import android.app.Activity; import android.database.Cursor; import android.database.sqlite.sqliteDatabase; import android.os.Bundle; public class DbtestActivity extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // com.test.db 是程序的包名,请根据自己的程序调整 // /data/data/com.test.db/ // databases 目录是准备放 sqlite 数据库的地方,也是 Android 程序默认的数据库存储目录 // 数据库名为 test.db String DB_PATH = "/data/data/com.test.db/databases/"; String DB_NAME = "test.db"; // 检查 sqlite 数据库文件是否存在 if ((new File(DB_PATH + DB_NAME)).exists() == false) { // 如 sqlite 数据库文件不存在,再检查一下 database 目录是否存在 File f = new File(DB_PATH); // 如 database 目录不存在,新建该目录 if (!f.exists()) { f.mkdir(); } try { // 得到 assets 目录下我们实现准备好的 sqlite 数据库作为输入流 InputStream is = getBaseContext().getAssets().open(DB_NAME); // 输出流 OutputStream os = new FileOutputStream(DB_PATH + DB_NAME); // 文件写入 byte[] buffer = new byte[1024]; int length; while ((length = is.read(buffer)) > 0) { os.write(buffer, 0, length); } // 关闭文件流 os.flush(); os.close(); is.close(); } catch (Exception e) { e.printStackTrace(); } } // 下面测试 /data/data/com.test.db/databases/ 下的数据库是否能正常工作 sqliteDatabase database = sqliteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null); Cursor cursor = database.rawQuery("select * from test", null); if (cursor.getCount() > 0) { cursor.moveToFirst(); try { // 解决中文乱码问题 byte test[] = cursor.getBlob(0); String strtest = new String(test, "utf-8").trim(); // 看输出的信息是否正确 System.out.println(strtest); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } cursor.close(); } }
程序启动时候回去检查数据库文件在不在,如果不存在,就会把我们准备好的数据库复制到哪个 databases
目录下,而且如果用户卸载了这个程序,那么这个目录和数据库也将随之卸载。
该程序可以提供中国大陆及香港、澳门、台湾各城市实时天气,所有数据来源于中国国家气象局,准确率相当高。
程序代码比较乱,没来得及整理,如果你对此有兴趣,可参见项目地址 https://github.com/libuchao/KWeather
参考文章:
Using your own SQLite database in Android applications
Embed a database in the .apk of a distributed application [Android]
解决这个问题后,花了几天找了一下天气预报的实现方式,其实最主要的是寻找数据源,靠谱的数据源很少很少。
最终决定用 weather.com.cn
这个比较权威的数据源,其提供的数据格式是 JSON,并参考了 通过 weather.com.cn 获取全国天气数据 这篇文章,最终简单实现了天气预报功能