Android读写CSV文件

首先在build.gradle的dependencies里面添加

        implementation 'com.opencsv:opencsv:5.4'//读csv文件

如果需要混淆的话,添加混淆

#CSV
-dontwarn com.opencsv.**
-dontwarn org.apache.commons.beanutils.**
-dontwarn org.apache.commons.collections.**
-keepattributes *Annotation*,Signature,InnerClasses,EnclosingMethod
-dontoptimize

然后就是读文件了

/**
     * 从文件读数据
     */
    private void readFile(){
        showLoadingDialog();
        new Thread(){
            @Override
            public void run() {
                try {
                    File file = new File("filePath");
                    // 创建 CSVReader 对象并指定要读取的文件路径
                    CSVReader reader = new CSVReader(new FileReader(file.getAbsolutePath()));

                    String[] nextLine;
                    int lineNum = 0;

                    Log.i("llllll", "开始读啦啦啦");
                    while ((nextLine = reader.readNext()) != null) {
                        int num = nextLine.length;//一行有几列
                        String str = "";
                        for(int j = 0;j<num;j++){
                            str += str + " ";
                        }
                        System.out.println(str);//打印每行信息,这里就可根据需求存储数据了
                        lineNum++;
                    }
                    Log.i("llllll", "读完了啦啦啦 lineNum = "+ lineNum);
                    // 关闭 CSVReader
                    reader.close();

                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }.start();
    }

写CSV文件

public static void writeToCsvFile(String filePath, List<String[]> data) throws Exception {
        File file = new File(filePath);
        if (file.exists()){
            file.delete();
        }
        FileWriter fileWriter = new FileWriter(file);
        CSVWriter csvWriter = new CSVWriter(fileWriter);

        for (String[] d : data) {
            csvWriter.writeNext(d);
        }
        csvWriter.close();
        fileWriter.close();
    }

这样就完成读写csv文件了!但是,这样写的csv文件有一个问题,就是有些字母会出现乱码情况。这是因为编码问题导致的。在写csv文件的时候需要指定编码格式为“UTF-8”,并且写入一行

fos.write(new byte[]{(byte) 0xEF, (byte) 0xBB, (byte) 0xBF});

写csv文件的方法优化如下:

/**
     * 数据保存成是csv文件
     * @param filePath  csv文件的路径
     * @param data     csv文件的内容
     * @throws Exception
     */
    public static void writeToCsvFile(String filePath, List<String[]> data) throws Exception {
        File file = new File(filePath);
        if (file.exists()){
            file.delete();
        }
        try (FileOutputStream fos = new FileOutputStream(file);
             OutputStreamWriter osw = new OutputStreamWriter(fos, "UTF-8"); // 设置编码为 UTF-8
             CSVWriter csvWriter = new CSVWriter(osw)) {
            fos.write(new byte[]{(byte) 0xEF, (byte) 0xBB, (byte) 0xBF});//来代码中的这个是为了解决乱码用的
            for (String[] d : data) {
                csvWriter.writeNext(d);
            }
            // csvWriter.close(); // 不需要显式关闭,因为使用了 try-with-resources
            // fileWriter.close(); // 这里没有 fileWriter,因为您使用了 OutputStreamWriter
        }

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android可以通过以下步骤来CSV文件: 1. 在Android项目中创建一个包含CSV文件的assets文件夹。如果没有assets文件夹,可以在项目的app模块下创建一个。 2. 使用CSVReader类来CSV文件CSVReader是由第三方库OpenCSV提供的。要使用OpenCSV库,需要先在build.gradle文件中添加依赖关系。 ``` dependencies { implementation 'com.opencsv:opencsv:5.5.2' } ``` 3. 在您的代码中使用CSVReader来CSV文件。以下是一个简单的示例: ```java import com.opencsv.CSVReader; import java.io.InputStreamReader; import java.io.IOException; import android.content.res.AssetManager; // ... try { AssetManager assetManager = getAssets(); InputStreamReader csvStreamReader = new InputStreamReader(assetManager.open("filename.csv")); CSVReader csvReader = new CSVReader(csvStreamReader); String[] nextLine; while ((nextLine = csvReader.readNext()) != null) { // 在此处进行您的操作,例如打印每一行的内容 for (String data : nextLine) { System.out.println(data); } } } catch (IOException e) { e.printStackTrace(); } ``` 在上面的示例中,我们使用getAssets()方法获取AssetManager的实例,并使用open()方法打开CSV文件的InputStreamReader。然后我们创建一个CSVReader对象,并使用readNext()方法逐行CSV文件,直到文件末尾为止。 这是一个基本的例子,您可以根据自己的需求对CSV文件进行其他操作,如将数据存储到数据库或在应用程序中显示。希望对您有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值