加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

关于Andriod读入CVS或者TXT文件的有关问题

发布时间:2020-12-12 20:40:59 所属栏目:百科 来源:网络整理
导读:一直在网上找能成功把CVS、TXT文件中的中文正确读入SQLITE的程序, 可惜没能成功,如果有谁有成功的程序请回帖告诉我,多谢! 以下是我自己借助了网上一些人的code, 实现从CVS(或者TXT)文件中把中文读入Android程序的String中, 再往后想把这个String插入

一直在网上找能成功把CVS、TXT文件中的中文正确读入SQLITE的程序, 可惜没能成功,如果有谁有成功的程序请回帖告诉我,多谢!


以下是我自己借助了网上一些人的code, 实现从CVS(或者TXT)文件中把中文读入Android程序的String中, 再往后想把这个String插入SQLITE中就很简单了, 大伙自己去弄吧。


    private void copyDataBase() throws IOException{
   	 
    	//首先, 打开CSV(或者TXT)。当然, 之前你需要把这个文件放入项目的assets文件夹中
    	InputStream is = this.getAssets().open("test.csv");
 
    	Log.e("length of InputSream",Integer.toString(is.available()));
    	
    	//这个sb的作用是可以把文件中所有行的文字全部读到一个String中,这个String
    	//后面定义为 result_all,如果你不要这个功能,可以删除下行
    	StringBuffer sb = new StringBuffer();  
    	String result_all;
  
    	//注意:一定要用GB2312的方式读入,因为我们的EXCEL直接生成的CSV文件
    	//或者windows下新建的TXT文档都是“GB2312”编码方式。
        BufferedReader br = new BufferedReader(  
                new InputStreamReader(is,"GB2312"));  
                
        String data = "";  
        int result_lines = 0;
        
        //下面是为了初始化一个String字符组放各行的数据,不过为了知道这个字符组要多大,所以先取得String字符组的大小
        int mark_Limit = is.available();
        
        if (br.markSupported())
        {
        	br.mark(mark_Limit);
        }else{
        	Log.e("TAG","error!");
        }
        
        while ((data = br.readLine()) != null) {  
        	result_lines++;
        }
        
        //得到了String字符组大小result_lines后,初始化这个字符组
        String[] result = new String[result_lines];

        br.reset();
        result_lines = 0;
        
        //以下是一行一行地从br里把文字读出来。
        while ((data = br.readLine()) != null) {  
            sb.append(data);  //本行目的是为形成result_all,如果不要可删除
            result[result_lines] = data;
            Log.e("result",result[result_lines]);
            result_lines++;
            
        }  
        
        String result_all1 = sb.toString();  

    	is.close();
 
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读