Android 导出CSV文件乱码问题处理

最近有一个需求,需要在Android端导出CSV文件,自测是用的WPS,没啥问题。可到了测试那边,用Excel直接打开就是乱码,需要在Excel数据里面用【从文件/CSV】打开。这样就显示非常的不方便。

解决办法:

java 复制代码
public static void exportToCsv(List<String[]> data, String filePath) throws IOException {
        File csvFolder = new File(FileIO.CSV_PATH);
        boolean isPresent = csvFolder.exists();
        if (!isPresent) {
            csvFolder.mkdir();
        }
        //FileWriter writer = new FileWriter(filePath);
        FileOutputStream fos = new FileOutputStream(filePath);
        // 写入BOM
        fos.write(0xEF); // 239
        fos.write(0xBB); // 191
        fos.write(0xBF); // 189
        OutputStreamWriter writer = new OutputStreamWriter(fos, StandardCharsets.UTF_8);
        for (String[] row : data) {
            String csvRow = String.join(",", row);

            writer.write(csvRow + "\n");
        }
        writer.flush();
        writer.close();
    }

解决方案:使用UTF-8 BOM。

相关推荐
simplepeng8 小时前
我们都知道但总是忽略的5个Jetpack Compose细节
android·android jetpack
刮风那天8 小时前
Android 如何提高进程优先级避免被查杀?
android
修行者对66610 小时前
安卓阿里云镜像
android
刮风那天10 小时前
Android AMS创建进程不用Binder而用Socket?
android·java·binder
知行合一。。。12 小时前
Python--05--面向对象(继承,多态)
android·开发语言·python
张小潇13 小时前
AOSP15 WMS/AMS系统开发 -窗口动画源码分析
android
程序员陆业聪15 小时前
Shadow核心原理:壳子Activity与代理机制的精妙设计
android
plainGeekDev15 小时前
Android 开发者再不转Kotlin,真的来不及了
android·kotlin
赏金术士15 小时前
第五章:数据层—网络请求与Repository
android·kotlin·compose
初雪云16 小时前
让安卓发版再简单一点,体验一键自动化发布
android·运维·自动化