当前位置: 首页 > news >正文

[bug]java导出csv用Microsoft Office Excel打开乱码解决

[bug]java导出csv用Microsoft Office Excel打开乱码

现象

首先这个csv文件用macbook自带的 "Numbers表格" 软件打开是不乱码的image,

但是使用者是Windows系统,他的电脑没有"Numbers表格"工具,

image

他用Microsoft Office Excel打开之后出现乱码,如下图所示:

image

解决方式

我网上查了下说是编码问题,有个最简单的办法,添加这行代码: "writer.write("\ufeff");"

我试了一下,发现好使, 另外我这个代码是之前的开发人员写的代码,我只是在这个代码添加了箭头指向的"writer.write("\ufeff");" 一行代码,然后乱码问题就解决了.

image

此时导出的csv文件用 Microsoft Office Excel 导出不乱码了.

image

ai大模型解释writer.write("\ufeff"); 是什么意思

这行代码 writer.write("\ufeff"); 是在 CSV 文件的开头写入一个 UTF-8 的字节顺序标记(BOM)。这是一个很好的做法,特别是当你希望 Excel 能正确识别 UTF-8 编码的 CSV 文件时。让我解释一下这行代码的作用和重要性:

  1. \ufeff 是 Unicode 字符 U+FEFF 的表示,也称为零宽度非换行空格(Zero Width No-Break Space)。
  2. 当这个字符出现在 UTF-8 编码的文件开头时,它被称为 UTF-8 BOM(Byte Order Mark)。
  3. BOM 的主要作用是标识文件的编码方式。对于 UTF-8 编码的文件,BOM 不是必需的,但它可以帮助一些应用程序(如 Microsoft Excel)正确识别文件编码。
  4. 特别是在处理包含非 ASCII 字符(如中文)的 CSV 文件时,添加 BOM 可以显著提高文件在 Excel 中的兼容性,避免乱码问题。
  5. 当 Excel 打开带有 UTF-8 BOM 的 CSV 文件时,它会自动识别为 UTF-8 编码,从而正确显示所有字符。

在你的代码中,这行语句确保了生成的 CSV 文件在 Excel 中打开时能够正确显示中文等非 ASCII 字符。这是一个很好的做法,特别是考虑到你的应用可能处理多语言内容。

如果你遇到某些系统或应用无法正确处理带 BOM 的文件,你可以考虑根据具体需求来决定是否包含这个 BOM。但对于主要面向 Excel 用户的 CSV 文件,包含 BOM 通常是一个好主意。

相关文章:

[bug]java导出csv用Microsoft Office Excel打开乱码解决

[bug]java导出csv用Microsoft Office Excel打开乱码 ‍ 现象 首先这个csv文件用macbook自带的 "Numbers表格" 软件打开是不乱码的, 但是使用者是Windows系统,他的电脑没有"Numbers表格"工具, ​​ 他用Microsoft Office Excel打开之后出现乱码,如下图…...

2023年区块链职业技能大赛——区块链应用技术(一)模块一

模块一:区块链产品方案设计及系统运维: 任务1-1:区块链产品需求分析与方案设计 1.依据给定区块链食品溯源系统的业务架构图,对考题进行业务分析,可能多的去考虑一个业务系统所需要的模块,使用Visio或思维导图工具展现本系统的基本设计概念和…...

4 软件工程——总体设计

一、设计过程 1.两个主要阶段 系统设计阶段:确定系统的具体实现方案结构设计阶段:确定软件结构 2.九个步骤 设想供选择的方案选取合理的方案推荐最佳方案功能分解设计软件结构设计数据库制定测试计划书写文档审查和复审 二、设计原理 1.模块化 模块…...

Elasticsearch:确保业务规则与语义搜索无缝协作

作者:来自 Elastic Kathleen DeRusso 利用查询规则与语义搜索和重新排序相结合的强大功能。 更多阅读: Elasticsearch 8.10 中引入查询规则 - query rules Elasticsearch 查询规则现已正式发布 - query rules 你是否知道查询规则(query ru…...

【大语言模型】ACL2024论文-33 Johnny 如何说服大型语言模型越狱:通过人性化 LLMs 重新思考挑战 AI 安全性的说服技巧

【大语言模型】ACL2024论文-33 Johnny 如何说服大型语言模型越狱:通过人性化 LLMs 重新思考挑战 AI 安全性的说服技巧 目录 文章目录 【大语言模型】ACL2024论文-33 Johnny 如何说服大型语言模型越狱:通过人性化 LLMs 重新思考挑战 AI 安全性的说服技巧目…...

【LuaFramework】LuaFramework_UGUI_V2框架学习

GitHub - jarjin/LuaFramework_UGUI_V2: 基于tolua的热更新框架V2 旧版本是Unity 5.0,这个是新版本支持更高版本的 导入工程后先清除wrap 然后重新生成wrap,你会发现有个报空null,框架的问题总结下所有的框架wrap相关报错问题和修复方法&…...

使用 AOP 在 Spring Boot 中实现跟踪和日志记录

在现代应用程序中,尤其是使用微服务构建的应用程序,跟踪和日志记录在跟踪流经各种服务的请求方面起着至关重要的作用。跟踪可帮助开发人员诊断问题、监控性能并了解用户在多个系统中的旅程。 在此博客中,我们将介绍如何使用traceId从前端生成…...

如何永久解决Apache Struts文件上传漏洞

Apache Struts又双叒叕爆文件上传漏洞了。 自Apache Struts框架发布以来,就存在多个版本的漏洞,其中一些漏洞涉及到文件上传功能。这些漏洞可能允许攻击者通过构造特定的请求来绕过安全限制,从而上传恶意文件。虽然每次官方都发布补丁进行修…...

FPGA远程升级 -- FLASH控制

简介 前文讲到如何实现XILINX芯片程序跳转,但升级程序是事先通过VIVADO工具将两个程序合成一个BIN文件实现升级的,并不能在线更新升级。要实现远程升级的能力需要对FPGA的FLASH进行在线写入升级程序。 FLASH介绍 本次设计FLASH选用的是S25FL128芯片&…...

企业内训|高智能数据构建、Agent研发及AI测评技术内训-吉林省某汽车厂商

吉林省某汽车厂商为提升员工在AI大模型技术方面的知识和实践能力,举办本次为期8天的综合培训课程。本课程分为两大部分:面向全体团队成员的AI大模型技术结构与行业应用,以及针对技术团队的高智能数据构建与Agent研发。课程内容涵盖非结构化数…...

ARM异常处理 M33

1. ARMv8-M异常类型及其详细解释 ARMv8-M Exception分为两类:预定义系统异常(015)和外部中断(1616N)。 各种异常的状态可以通过Status bit查看,获取更信息的异常原因: CFSR是由UFSR、BFSR和MMFSR组成: 下面列举HFSR、MMFSR、…...

(补)算法刷题Day24: BM61 矩阵最长递增路径

题目链接 思路 方法一:dfs暴力回溯 使用原始used数组4个方向遍历框架 , 全局添加一个最大值判断最大的路径长度。 方法二:加上dp数组记忆的优雅回溯 抛弃掉used数组,使用dp数组来记忆遍历过的节点的最长递增路径长度。每遍历到已…...

探索 Bokeh:轻松创建交互式数据可视化的强大工具

探索 Bokeh:轻松创建交互式数据可视化的强大工具 在数据科学和数据分析领域,交互式数据可视化是一项不可或缺的技能。Bokeh 是一个强大的 Python 库,它可以帮助我们快速构建高质量的交互式图表和仪表盘,同时兼具高性能和灵活性。…...

【Rust自学】6.1. 定义枚举

喜欢的话别忘了点赞、收藏加关注哦,对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 6.1.1. 什么是枚举 枚举允许我们列举所有可能的值来定义一个类型。这与其他编程语言中的枚举类似,但 Rust 的枚举更加灵活和强…...

【Java基础面试题035】什么是Java泛型的上下界限定符?

回答重点 Java泛型的上下界限定符用于对泛型类型参数进行范围限制,主要有上界限定符和下届限定符。 1)上界限定符 (? extends T): 定义:通配符?的类型必须是T或者T的子类,保证集合元素一定是T或者T的子类作用&…...

0基础学前端系列 -- 深入理解 HTML 布局

在现代网页设计中,布局是至关重要的一环。良好的布局不仅能提升用户体验,还能使内容更具可读性和美观性。HTML(超文本标记语言)结合 CSS(层叠样式表)为我们提供了多种布局方式。本文将详细介绍流式布局、Fl…...

【python高级】342-TCP服务器开发流程

CS模式:客户端-服务端模式 TCP客户端开发流程介绍(五步)(C端) 1.创建客户端套接字对象 2.和服务端套接字建立连接 3.发送数据 4.接收数据 5.关闭客户端套接字 TCP服务端开发流程(七步)&#xf…...

《计算机组成及汇编语言原理》阅读笔记:p48-p81

《计算机组成及汇编语言原理》学习第 4 天,p48-p81 总结,总计 34 页。 一、技术总结 1.CISC vs RISC p49, complex instruction set computing For example, a complex instruction set computing (CISC) chip may be able to move a lar…...

AI在传统周公解梦中的技术实践与应用

本文深入探讨了人工智能在传统周公解梦领域的技术实践与应用。首先介绍了传统周公解梦的背景与局限性,随后详细阐述了 AI 技术如何应用于梦境数据的采集、整理与分析,包括自然语言处理技术对梦境描述的理解,机器学习算法构建解梦模型以及深度…...

GIS数据处理/程序/指导,街景百度热力图POI路网建筑物AOI等

简介其他数据处理/程序/指导!!!(1)街景数据获取(2)街景语义分割后像素提取,指标计算代码(绿视率,天空开阔度、视觉熵/景观多样性等)(3…...

大模型概述1

一个中文字符大约0.6个token,一个英文单词一般0.3个token,不同的大模型有自己不同的tokenize。令牌化的方法。FLOPs:算力的参数,多少此浮点型运算大模型分类:分类方式一:多模态的,多种形态的模型…...

每日极客日报 · 2026年04月11日

每日极客日报 2026年04月11日 今日精选 20 条 IT 科技热点,覆盖 AI 大模型、开源生态、业界动态与工程实践等领域。GPT-6 定档 4 月 14 日、法国政府宣布全面放弃 Windows 转向 Linux、Anthropic 与 CoreWeave 签下多年算力大单——周六的科技圈依然热闹。 &#x…...

OpenLayers7实战速成:从零构建你的第一个WebGIS应用

1. 为什么选择OpenLayers7? 如果你正在寻找一个强大且免费的开源WebGIS开发库,OpenLayers7绝对值得考虑。作为一个长期从事地图开发的老兵,我见证了这个库从最初的复杂难用到现在的简洁高效。最新版本不仅性能大幅提升,API设计也更…...

如何通过二进制补丁技术实现微信QQ消息防撤回功能

如何通过二进制补丁技术实现微信QQ消息防撤回功能 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: https://gitcode.com/GitHub_Trendi…...

Pixel Couplet Gen惊艳案例:神荼郁垒像素方块+物理卷轴动态渲染

Pixel Couplet Gen惊艳案例:神荼郁垒像素方块物理卷轴动态渲染 1. 项目概览 当AI技术遇上复古游戏美学,Pixel Couplet Gen为我们带来了一场视觉与文化的盛宴。这款基于ModelScope大模型的春联生成器,彻底颠覆了传统春联的设计语言&#xff…...

Betaflight飞控系统:如何通过3个关键步骤解决你的无人机飞行难题?

Betaflight飞控系统:如何通过3个关键步骤解决你的无人机飞行难题? 【免费下载链接】betaflight Open Source Flight Controller Firmware 项目地址: https://gitcode.com/gh_mirrors/be/betaflight 你是否曾经在飞行中遭遇机身抖动、响应迟钝或者…...

OpenCore引导菜单深度解析:从单调文本到专业图形界面的进阶调优

OpenCore引导菜单深度解析:从单调文本到专业图形界面的进阶调优 【免费下载链接】OpenCore-Install-Guide Repo for the OpenCore Install Guide 项目地址: https://gitcode.com/gh_mirrors/op/OpenCore-Install-Guide OpenCore作为现代黑苹果引导方案的核心…...

深度解析Cursor Pro激活器:3层架构突破AI代码编辑器限制的技术实现

深度解析Cursor Pro激活器:3层架构突破AI代码编辑器限制的技术实现 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reac…...

React 实现 AI 流式打字机对话:SSE 分包粘包处理 + 并发优化

核心功能说明 完全对标豆包官网,涵盖所有生产级必备功能,无任何冗余逻辑: SSE 标准流式解析:兼容所有主流大模型(豆包、通义千问、ChatGPT),严格处理 TCP 分包/粘包,不丢字、不乱码。…...

STM32上跑矩阵运算老是卡死?可能是你没避开CMSIS-DSP库的这些‘坑’

STM32上跑矩阵运算老是卡死?可能是你没避开CMSIS-DSP库的这些‘坑’ 当你第一次在STM32上尝试使用CMSIS-DSP库进行矩阵运算时,那种兴奋感很快就会被现实浇灭——程序莫名其妙地卡死、计算结果全错,或者性能远低于预期。这不是你的错&#xf…...