java导入EXCLE时文件名中文乱码

String userAgent = request.getHeader("USER-AGENT");//  文件名,包含后缀
if (StringUtils.contains(userAgent, "Chrome") || StringUtils.contains(userAgent, "Firefox")) { //  google,火狐浏览器
name = new String((name).getBytes(), "ISO8859-1");
} else {
name = URLEncoder.encode(name, "UTF8"); // 其他浏览器
}
Java导入Excel的嵌入式图片可以使用Apache POI库来实现。首先,需要添加Apache POI和Apache POI-OOXML的依赖。 导入嵌入式图片的过程如下: 1. 使用`WorkbookFactory.create()`方法加载Excel文件,创建Workbook对象。 2. 获取Sheet对象,用来操作具体的工作表。 3. 遍历Sheet对象的所有行和单元格,寻找嵌入式图片。 4. 如果某个单元格的内容是嵌入式图片,使用`getCellComment()`方法获取CellComment对象。 5. 使用CellComment对象的`getString()`方法获取Base64编码的图片数据。 6. 解码Base64编码的图片数据,将其保存到本地文件。 以下是一个简单的示例代码,展示如何导入Excel的嵌入式图片: ``` import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.ss.util.CellRangeAddressList; import org.apache.poi.xssf.usermodel.*; import javax.imageio.ImageIO; import java.awt.image.BufferedImage; import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; public class ExcelImageImporter { public static void main(String[] args) { String excelFilePath = "path/to/excel.xlsx"; try { Workbook workbook = WorkbookFactory.create(new File(excelFilePath)); Sheet sheet = workbook.getSheetAt(0); for (Row row : sheet) { for (Cell cell : row) { CellType cellType = cell.getCellType(); if (cellType == CellType.STRING && cell.getCellComment() != null) { CellComment comment = cell.getCellComment(); String commentString = comment.getString().getString(); // 解码Base64编码的数据 byte[] imageData = java.util.Base64.getDecoder().decode(commentString); // 将图片数据保存为本地文件 FileOutputStream outputStream = new FileOutputStream("image.png"); outputStream.write(imageData); outputStream.close(); System.out.println("成功导入图片!"); } } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上代码片段的`excelFilePath`变量需要替换为实际的Excel文件路径。在执行该代码之后,嵌入式图片将被保存在本地的image.png文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值