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。

相关推荐
PoppyBu21 分钟前
Ubuntu20.04版本上安装最新版本的scrcpy工具
android·ubuntu
执念、坚持30 分钟前
Property Service源码分析
android
用户416596736935539 分钟前
在 ViewPager2 + Fragment 架构中玩转 Jetpack Compose
android
GoldenPlayer44 分钟前
Gradle脚本执行
android
用户745890020795444 分钟前
Android进程模型基础
android
we1less1 小时前
[audio] Audio debug
android
Jomurphys1 小时前
AndroidStudio - TOML
android
有位神秘人1 小时前
Android最新动态权限申请工具
android
lxysbly1 小时前
psp模拟器安卓版下载汉化版2026
android
2501_941822752 小时前
面向灰度发布与风险隔离的互联网系统演进策略与多语言工程实践分享方法论记录思考汇总稿件
android·java·人工智能