读取CSV文件并存储到ArrayList中

4 篇文章 0 订阅
1 篇文章 0 订阅

一些应用需要一些文档或者说是数据,我们不可能在代码中一个一个的编写,这里就要用到CSV文件了(即excel存储的文件格式)

代码如下:

package com.example.sendmsg;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;

import android.content.Context;

public class CsvList {
    private Context context;
    private ArrayList<Festival> csvList = new ArrayList<Festival>();

    public CsvList(Context context){
        this.context = context;
    }

    public ArrayList<Festival> getList(String fileName){
        try {   


               BufferedReader reader = new BufferedReader(new InputStreamReader(context.getResources().getAssets().open(fileName),"GBK"));//换成你的文件名    
               // reader.readLine();//第一行信息,为标题信息,不用,如果需要,注释掉     
               String line = ""; 

               while((line = reader.readLine())!=null){ 
                  //Toast.makeText(FestivalListActivity.this, "line"+line, Toast.LENGTH_LONG).show();
                   String item[] = line.split(",");//CSV格式文件为逗号分隔符文件,这里根据逗号切分 

                   Festival festival = new Festival();//创建Festival对象

                   festival.setId(item[0]);//写入Id        
                   festival.setName(item[1]);//写入name
                   festival.setContent(item[2]);//写入content
                   festival.setIcon(item[3]);//写入Icon
                   csvList.add(festival);//添加到 List内
               }        
             }catch(Exception e){ 
                   e.printStackTrace(); 
             } 
        return csvList;
    }
}

这里的csv文件我是放在assets文件下的。

这里就可以存储到数据库中,方便调用其中的数据。(很方便的调用)

代码如下:(这边只是一个方法,csvList即上面的csvList)

    //insert data
    public boolean insertData(ArrayList<Festival> csvList){
        long resCode = -1L;//判定是否添加成功的数据
        // 创建ContentValues对象
        //判断表中是否有数据,没有则添加
        Cursor cursor = sqliteDatabase.rawQuery("select * from festival", null);
        if(cursor.getCount()==0){
            ContentValues values = new ContentValues();
            for(int i = 0;i<csvList.size();i++){
                values.put("id", csvList.get(i).getId());
                values.put("name", csvList.get(i).getName());
                values.put("icon", csvList.get(i).getIcon());
                resCode = sqliteDatabase.insert("festival", null, values);          
            }
        }
        Cursor cursor_ = sqliteDatabase.rawQuery("select * from festcontent", null);
        if(cursor_.getCount()==0){
            ContentValues values_ = new ContentValues();
            for(int i = 0;i < csvList.size();i++){
                values_.put("id", csvList.get(i).getId());
                values_.put("content", csvList.get(i).getContent());
                resCode = sqliteDatabase.insert("festcontent", null, values_);
            }
        }
        if(resCode == -1) return false;
        return true;
    }
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Spring MVC将CSV文件的数据读取到数据库的代码示例: 1. 定义实体类 首先,定义一个实体类来存储CSV文件的数据。示例实体类如下: ```java public class CsvData { private String name; private String email; private String phone; // getters and setters } ``` 2. 创建CSV文件上传表单 在前端创建一个表单,用于上传CSV文件。示例代码如下: ```html <form method="post" action="/upload" enctype="multipart/form-data"> <input type="file" name="file" /> <button type="submit">Upload</button> </form> ``` 3. 创建Controller 创建一个Controller,处理上传CSV文件的请求并将数据存储到数据库。示例代码如下: ```java @Controller public class CsvController { @Autowired private CsvService csvService; @PostMapping("/upload") public String uploadCsv(@RequestParam("file") MultipartFile file) { try { List<CsvData> csvDataList = csvService.readCsv(file.getInputStream()); csvService.saveCsvData(csvDataList); return "success"; } catch (Exception e) { e.printStackTrace(); return "error"; } } } ``` 4. 创建Service 创建一个Service,用于读取CSV文件的数据并将其存储到数据库。示例代码如下: ```java @Service public class CsvService { @Autowired private CsvRepository csvRepository; public List<CsvData> readCsv(InputStream inputStream) throws IOException { List<CsvData> csvDataList = new ArrayList<>(); try (BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream))) { String line; while ((line = bufferedReader.readLine()) != null) { String[] data = line.split(","); CsvData csvData = new CsvData(); csvData.setName(data[0]); csvData.setEmail(data[1]); csvData.setPhone(data[2]); csvDataList.add(csvData); } } return csvDataList; } public void saveCsvData(List<CsvData> csvDataList) { csvRepository.saveAll(csvDataList); } } ``` 5. 创建Repository 创建一个Repository,用于将CSV文件的数据存储到数据库。示例代码如下: ```java public interface CsvRepository extends JpaRepository<CsvData, Long> { // empty } ``` 这样,当用户上传CSV文件时,Controller会调用Service来读取CSV文件的数据并将其存储到数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值