//文件读写
//在导入项目中的数据库中把数据从中去出来
调用例:readSql(a,"comminnum.db",f);
public void readSql(Context context,String path,File tofile){ BufferedInputStream bis=null; BufferedOutputStream bos=null; int len=0;
byte []bt=new byte[1024]; try { bis=new BufferedInputStream(context.getAssets().open(path));//实例化输入流path为数据库路径,一般写数据库名就行,open是InputStream类型的
bos=new BufferedOutputStream(new FileOutputStream(tofile)); //实例化输出流 while ((len=bis.read(bt))!=-1){ bos.write(bt,0,len); } } catch (IOException e) { e.printStackTrace(); }finally { if(bis!=null){ try { bis.close(); } catch (IOException e) { e.printStackTrace(); } } if(bos!=null){ try { bos.close(); } catch (IOException e) { e.printStackTrace(); } } } }
//文件创建
File file=null; public void createFile(Context context){
//判断是否存在sd卡,有返回true
if(Environment.getExternalStorageDirectory().equals(Environment.MEDIA_MOUNTED)){
//有sd卡 file=new File("data"+File.separator+"data"+File.separator+Environment.getExternalStorageDirectory()+File.separator+"stusystem.db"); if(!file.getParentFile().exists()){ file.getParentFile().mkdirs(); } if(!file.exists()){ try { file.createNewFile(); } catch (IOException e) { e.printStackTrace(); } } }else{
//没有SD卡 file=new File("data"+ File.separator+"data"+File.separator+context.getPackageName()+File.separator+"stusystem.db"); if(!file.getParentFile().exists()){ file.getParentFile().mkdirs(); } if(!file.exists()){ try { file.createNewFile(); } catch (IOException e) { e.printStackTrace(); } } } }